This application claims priority to European Patent Application No. 20158613.8 filed on Feb. 20, 2020, incorporated herein by reference in its entirety.
The present disclosure is related to methods, recording mediums and systems for processing at least one image, and vehicles including the systems.
It has been proposed to use neural networks, for example convolutional neural network or feed-forward neural networks, to process data.
By way of example, it has been proposed to process images through such neural networks, for example to detect objects on images. Typically, in a training phase, known images are inputted to the neural network and a scoring system is used to adjust the neural network so that it behaves as expected on these known images. The neural networks are then used in a phase called a testing phase on actual images without any knowledge of the expected output.
The expression “neural network” used in the present application can cover a combination of a plurality of known networks.
A typical application of these image processing neural networks is the detection of objects in driving scenes so as to allow autonomous driving.
Generally, merely detecting that objects are visible is not sufficient and it is desirable to obtain the position in space (for example with respect to a vehicle equipped with a camera acquiring an image to be processed) and the orientation in space of detected objects. The position and the orientation in space of an object is called the 6D pose.
Detecting the 6D pose allows a vehicle to have knowledge of its surrounding and especially of the other vehicles.
Known methods perform a detection of, for example, a specific object so as to determine the 6D pose of this object when it is detected. This is too limiting and cannot be applied in a driving scene context wherein there are too many different models of vehicles.
Many other applications in which features which qualify an object other than the 6D pose still show poor performances.
There is a need for more efficient methods to process images.
The present disclosure overcomes one or more deficiencies of the prior art by proposing a method for processing at least one image comprising inputting the image to at least one neural network, the at least one neural network being configured to deliver, for each pixel of a group of pixels belonging to an object of a given type visible on the image, an estimation of object parameters that are parameters of the object, the method further comprising processing the estimations of the object parameters using an instance segmentation mask identifying instances of objects having the given type.
The at least one image can be an image acquired by an image acquisition device from a set of image acquisition devices (and all the images from each image acquisition device can be processed using the above method) which may, for example, surround a vehicle.
The processing can comprise averaging the parameters over all the pixels of the group of pixels.
The at least one image may also be a frame from a video sequence.
It has been observed by the inventors of the present disclosure that it is possible to train a neural network so that it is configured to deliver an object parameter (or more precisely a value of an object parameter), for several (for example every) pixels which may belong to this object, and that this provides an even more precise estimation of this parameter. For example, the training can comprise using annotated data wherein the object parameters for objects of the given type are provided.
The group of pixels can include all the pixels that do belong to the object or merely a portion of the pixels that belong to the object, for example if a down-sampling is carried out.
It should be noted that the neural network may be configured to also deliver an estimation of parameters for pixels that do not belong to an object having the given type, and that these estimations may be random and without meaning.
By combining the instance segmentation mask and the estimations of the parameters available for every pixels in the group of pixels, it is possible to deduce, for the objects having the given type, a more precise estimation of the parameters.
Also, the expression “deliver” is directed to both the final output of the at least one neural network and to intermediary outputs.
It should be noted that in the present application, the type of an object, for example the given type as mentioned above, relate to an object type which may be a category including a plurality of distinct models. For example, the type can be vehicles and the object parameters can be delivered for every vehicle visible on the image regardless of the model, and “vehicle” includes cars, busses, etc. The training phase used to train the at least one neural network will therefore be done on images showing vehicles (cars, busses, etc.), for which the following elements are known:
Thus, the method can detect object parameters without having knowledge of a specific model of car.
Should the given type be more specific, for example “car”, the training will be performed using images showing different models of cars.
Consequentially, the given type is defined in a preliminary training step and depends on what are the objects visible on the images used during training.
The advantages of the above method are related to the fact that many (for example all) the pixels of an object can contribute to the determination of the object parameters. This has been observed to provide good handling of occlusions of objects.
Also, the above method can be trained to be independent of the image acquisition device (i.e. camera independent) so as to be applied to different systems and especially different cameras. Once the neural network is configured as defined above, it can be used to process images from different cameras placed at different locations (for example on a vehicle) and therefore showing different scenes.
It should be noted that the image acquisition devices used to obtain the images processed by the present method may be fisheye cameras.
It has also been observed that it is possible to obtain statistics such as variance values for the object parameters (as every pixel of the group of pixels provides information on these object parameters), which can be used to measure uncertainty and in the tracking of objects.
In the above method, the instance segmentation mask can be provided from any known method for performing instance segmentation on images trained to identify objects having the given type. For example, it can be obtained using a neural network or using a portion of the at least one neural network which delivers said parameters.
It should be noted that the given type can be a type selected from a group of types of objects. For example, the segmentation mask can identify instances of objects having each type from the group of types of objects, and object parameters can be delivers for each pixel of a group of pixel belonging to an object having a type belonging to the group of types.
According to a particular embodiment, for each pixel of the group of pixels, the object parameters may be relative or a portion of the object parameters may be relative and a portion of the object parameters may be absolute.
By relative, what is meant is that the parameter of the object is relative to the pixel (or of its location, etc.). For example, if the parameter is a location (in the space of the image), it may be a relative location such as a displacement between the pixel and this location.
Having relative parameters has been observed to facilitate obtaining a method which is camera independent, without involving additional training steps.
An absolute parameter does not depend on the pixel (for example on its location, etc.). For example, an absolute location can be the location in 2D or 3D with respect to a referential which is the same for every pixel.
According to a particular embodiment, for each pixel of the group of pixels, the object parameters may include:
at least one 2D position element of the object in the at least one image, and/or
at least one 3D position element of the object in 3D space, and/or
at least one dimension element of the object in the at least one image, and/or
at least one dimension element of the object in 3D space,
at least one rotation element (for example defined by angles, sines and cosines of angles, quaternions, etc.).
The above listed object parameters can be either relative or absolute. It may be possible to select any combination of the above parameters depending on the application.
For example, it is possible to select parameters that allow determining the 6D pose of the object.
According to a particular embodiment, for each pixel of the group of pixels, the object parameters may include a plurality of 2D position elements comprising:
It should be noted that the neural network may be configured to deliver a displacement for all the pixels of the image (for example), but that “displacements” determined for pixels that do not belong to an object having the given type may be random and without meaning. By combining the instance segmentation mask and these displacements available for every pixels in the group of pixels, it is possible to deduce, position information of the object of the given type.
It should be noted that the displacement may also be called an offset by the person skilled in the art. A displacement is a relative parameter.
According to a particular embodiment, the reference points may be projections into a plane of the image of points at given positions in 3D space associated with the object.
The given positions can be positions in 3D space such as, for example, the 3D center of the object.
According to a particular embodiment, the given positions may be a plurality of corners of a 3D bounding box surrounding the object, and centroids of top and bottom faces of the 3D bounding box surrounding the object.
A 3D bounding box is a rectangular cuboid, typically the smallest cuboid enclosing the object to which it is associated.
In this embodiment, the given positions are the corners of the 3D bounding box. Alternatively, plurality of predefined positions on a 3D bounding box can be used.
Also, the number of given positions can be 2 or more given positions. According to an example, and given that the bounding boxes are symmetrical, it is possible to use 4 corners as given positions on every 3D bounding box.
According to a particular embodiment, the given positions may be a plurality of corners of a 3D bounding box surrounding the object, or the centroids of the top and bottom faces of the 3D bounding box surrounding the object.
The use of these centroids is particularly useful as it provides not only information on the position in 3D space of the object but also on its height (in pixels on the image or in meters in 3D space).
According to a particular embodiment, for each pixel of the group of pixels, the object parameters may include dimension elements of the object comprising a width and/or a height and/or a length of a 3D bounding box surrounding the object.
The width/height/length can be expressed in meters and are absolute parameters.
According to a particular embodiment, for each pixel of the group of pixels, the object parameters may include at least one rotation element including an angle between a viewing direction of the pixel and an object orientation that is an orientation of the object.
The pixel's viewing direction is the direction of a ray passing through the pixel and the center of the image acquisition device (camera) used to acquire the at least one image. The object orientation is the object orientation in 3D space, for example the orientation of the bounding box with respect to a reference (for example the image acquisition device) and defined by a ray passing through the object center and oriented in the general direction of the object (for a vehicle, from back to front).
The orientation of the object can be a horizontal yaw angle, which is particularly adapted for situations where objects are on a planar ground, which is typically the case for vehicles.
According to a particular embodiment, for each pixel of the group of pixels, the object parameters may include at least one rotation element including a rotation between a viewing direction of the pixel and an object orientation that is an orientation of the object, defined by a quaternion.
According to a particular embodiment, the method may further comprise determining a 6D pose of the object using results of the processing.
It has been observed that using estimations of different positions elements and/or angles and/or orientations for multiple pixels provides a good basis for determining the 6D pose.
The person skilled in the art will know which parameters are needed to determine the 6D pose of the object.
For example, if reference points are used which are projections of corners of a bounding box, determining where 4 reference points are in 3D space allows determining the 6D pose, using for example the intrinsic calibration of the image acquisition device.
According to a particular embodiment, the at least one image may be an image of a driving scene.
The disclosure also provides a method of tracking at least one object using a plurality of images each associated with different instants, comprising processing each image of the plurality of images using the method for processing as defined above.
This method is particularly useful when the 6D pose has been determined. It can also be applied to processing methods which only detect other object parameters.
According to a particular embodiment, for each instant there may be an additional plurality of images each showing different viewpoints, the method comprising identifying the at least one object on the basis of images from the additional plurality of images each showing the object to be identified.
The identifying step can include assigning a single variable to the object based on the plurality of detections performed by the processing methods on the plurality of images.
This embodiment is particularly useful to handle occlusions, appearing and disappearing objects, and this results from the use of a plurality of images each showing different viewpoints.
According to a particular embodiment, identifying the at least one object on the basis of images form the additional plurality of images each showing the object to be identified may comprise implementing a combinatorial assignment.
According to a particular embodiment, the method may further comprise obtaining a mean and a variance associated with each estimation of the object parameters from the group of pixels so as to predict a state of the object.
The mean and the variance have been observed to be particularly useful to perform predictions in the tracking, for example using Extended Kalman Filters.
The disclosure also provides a method for training at least one neural network to be used in the method as defined above.
It should be noted that the tracking may be performed by modules which are not machine-learning based which may not be affected by the training. Also, the training can include training the at least one neural network to deliver the instance segmentation mask.
According to a particular embodiment, the method may comprise inputting a plurality of training images to the at least one neural network showing different objects having the given type.
According to a particular embodiment, training images used to train the at least one neural network may be each associated with the object parameters of objects having the given type visible on the training images.
The disclosure also provides a system for processing at least one image comprising at least one neural network, the at least one neural network being configured to deliver, for each pixel of a group of pixels belonging to an object of a given type visible on the image, an estimation of object parameters that are parameters of the object, the system further comprising a module for processing the estimations of the object parameters using an instance segmentation mask identifying instances of objects having the given type.
This system may be configured to perform any embodiment of the method as defined above.
The disclosure also provides a vehicle including the system as defined above and at least one image acquisition device.
In one particular embodiment, the steps of the method are determined by computer program instructions.
The disclosure is also directed to a recording medium readable by a computer and having recorded thereon a computer program including instructions for executing the steps of the method as described above.
The recording medium can be any entity or device capable of storing the program. For example, the medium can include storage means such as a ROM, for example a CD ROM or a microelectronic circuit ROM, or magnetic storage means, for example a diskette (floppy disk) or a hard disk.
Alternatively, the recording medium can be an integrated circuit in which the program is incorporated, the circuit being adapted to execute the method in question or to be used in its execution.
How the present disclosure may be put into effect will now be described by way of example with reference to the appended drawings, in which:
An exemplary method for processing images will now be described.
In this exemplary method, the 6D pose of objects is determined. The disclosure is however not limited to the determination of 6D pose and can be directed to the determination of any object parameters.
Also, in the present description, the object parameters include relative displacements, angles, and rotations. Other object parameters can be delivered by the neural networks of the present disclosure.
Additionally, in the present disclosure, neural networks are used to determine the 6D pose and instance segmentation masks. The disclosure also applies to methods in which instance segmentation masks are determined using other known methods.
In the present description, vehicles are the objects of interest.
The present method can be performed on images acquired by a camera of a vehicle, typically Red-Green-Blue images.
In the present description, the 6D pose of an object can be determined on the basis of the determination of the location of a 3D bounding box surrounding this object and using as parameters displacements between pixels and reference points which are projections into the space of the image of given positions on a 3D bounding box.
For example, on
An alternative representation is shown on
An alternative to the yaw angle is the use of a quaternion.
Also, and as will be explained hereinafter, when an image is inputted to the one or several neural networks used to implement the disclosure, the at least one neural network is able to deliver: for each pixel of a group of pixels of the at least one image that belong to an object having a given type visible on the image, a displacement (a relative parameter) between the pixel and every reference point of the object of the pixel, wherein the reference points for a pixel represent projections into the plane of the at least one image of points at given positions in 3D space on a 3D bounding box surrounding the object of the pixel.
Examples of given positions were given in reference to
The following notation can be used:
r
i
=p+(Δu,Δv)i,p
All the pixels which deliver the displacements (Δu, Δv) provide information on the location of the reference points (for example by averaging the location over all pixels that belong to a same object or instance) so as to predict the position in the image space of the reference points. This may also allow averaging out the predictions for the height, the width, and the length of the object.
Additionally, it is possible to determine the distance between a detected object and the camera used to acquire the image on which this object is visible.
For example, on
The intrinsic parameters are used to re-project 2D points to rays in 3D space. Using the rays with dimensions predicted by the at least one neural network allows calculating the distance to the object and its position in 3D.
Also, using the intrinsic parameters allows re-projecting 2D points to rays in 3D space.
As shown on
Wherein {right arrow over (a)}{right arrow over (b)} is the dot product of {right arrow over (a)} and {right arrow over (b)}.
Thus, the distance d can be expressed using this angle and the height h measured between the top and bottom reference points:
If the given positions on the bounding box are chosen so as to respect the symmetry of the objects, as proposed on
The rotation of the car may also be obtained by compensating the predicted local viewing angles with the angle of each pixel's associated ray to the image acquisition device.
From the above, it can be seen how the 6D pose can be obtained.
It should be noted that in the above examples, it is assumed that the view is perpendicular with the observed objects.
An alternative is visible on
On this figure, C designates the camera center, R1 and R2 are a pair of reference points in 3D, θ1 is the angle between the rays of light towards the reference points, s is the predicted size (for example the height of the bounding box), α is the rotation of the object projected in the 2D plane formed by the two pixel rays. This rotation can either be determined by the predicted quaternion, or by using the extrinsic camera parameters assuming a ground plane to which objects are parallel. The following values visible on the figure can be calculated:
And, using the Law of Sines, the two distances to the given positions on a 3D bounding box are:
Thus, a closed-form solution is used to determine the 6D pose.
The angle between the light rays is thus used to determine the 6D pose. It is possible to represent the angles using sines and cosines and these can be obtained from a neural network. The joint use of sines and cosines allows predicting continuous values and avoid the ambiguity and discontinuities in the inverse trigonometric functions to recover the angle. (for example by using the average between the two). It has been observed that the front and rear of objects such as cars can be confused as they may look similar. By predicting/delivering the double of the angle, it is possible to disambiguate the detection of the orientation because whether the car appears to be left or right, the same angle will be obtained (the bounding box will be the same, without any information concerning which side is the front or rear side.
This flowchart uses an image segmentation method IS analogous to the one described in PCT application PCT/EP2019/051191, the contents of which are incorporated by reference.
The image IMG is first processed by an encoder ENC which is a portion of a neural network shared with different decoders.
Concerning the instance segmentation, the encoder ENC and two branches SB and IB form the neural network ANN1 which only performs instance segmentation. As explained in the above cited application, the branch IB predicts a pixel offset map POM and sigma maps SM.
The branch SB outputs N seed maps SeM, one for each semantic class or type CL1, CL2, etc. In this example, multiple objects can be detected, for example cars and pedestrians.
POM and SM, along with coordinate vectors xmap, ymap and margins M, provide a clustering margin representation CMR of the image in which clusters CM of pixels indicate an instance of an object. The clustering margin representation CMR is a type of instance segmentation mask for the image.
From this representation, it is possible to represent a mask OM on which different cars and pedestrians are identified and displayed.
The disclosure is not limited to the instance segmentation of the above cited application and many methods can be used.
The output of the shared encoder ENC is processed in another branch PB dedicated to the 6D pose. The encoder ENC and the branch PB form a second neural network ANN2, for example a convolutional neural network.
This neural network is configured to deliver multiple elements and therefore has the corresponding outputs and is trained accordingly. Among these delivered elements there is:
ΔuΔvMAP a map of values (Δu, Δv) for each pixel of the image and configured so that, for the pixels that have the type CL1 or CL2, there are two values indicating a displacement between the pixel and every reference point of the object of the pixel, wherein the reference points for a pixel represent projections into the plane of the at least one image of points at given positions in 3D space on a 3D bounding box surrounding the object of the pixel. For pixels that do not belong to an object of type CL1 or CL2, the outputted values are without meaning. (Δu, Δv) are relative parameters.
αMAP a map viewing angles representing the local angle for every pixel between the pixel ray of light and the yaw of the bounding box as explained in reference to
HWLMAP a map of height, width and length values for the above mentioned bounding boxes, determined for each pixel of the image but with correct values only for pixels belonging to an object of type CL1 or CL2. These values are absolute.
From the above, it can be seen that the same information is determined from a plurality of pixels. For example, the yaw angle and the width/height/length of a bounding box are determined for each pixel of the object, which allows obtaining a precise estimation. Additionally, the position in the plane of the image of the reference points is precisely estimated using as many pixels as possible: all the pixels that belong to an object.
In module 100, the instance segmentation mask CMR is used to act as a mask to only obtain only the (Δu, Δv) couples for pixels that belong to detected instances, and an average of these values is determined so as to obtain NREF the position in the plane of the image of the reference points of N 3D bounding boxes, N representing the number of detected objects/instances.
In module 101, the instance segmentation map CMR is used to act as a mask to obtain only the height/width/length values for the 3D bounding boxes of only the detected objects/instances (an average of all the values may be determined for pixels that belong to a same object).
In module 102, NREF, the output of module 101, and the intrinsic parameters CIN of the image acquisition device used to obtain IMG are used to obtain the position in space of the given positions on each bounding box 3DREF, using the calculations described in reference to
In module 1001, αMAP is compensated using the intrinsic parameters CIN so as to obtain absolute angle values (yaw values) for every pixel.
In module 1002, the instance segmentation mask CMR is used to act as a mask on the output of module 1001 to obtain the relevant yaw angles.
In module 103, the 6D poses 6DPOSE of all objects of types CL1 and CL2 visible on IMG are determined using the outputs of modules 102 and 1002. The pose P of an object i, relative to a camera, can be expressed as: Pi=[Ri, ti], wherein Ri∈SO(3) is a rotation component and ti∈R3 is the translation component. Training the neural network ANN1 can be done using the method described in application PCT/EP2019/051191.
Training the neural network ANN2 can be done using annotated images, i.e. Red-Green-Blue images for which an instance segmentation mask is known and for which the position of a bounding box (or of its projection or of its reference points) is known. The image acquisition device intrinsic parameters may also be used during training.
LIDAR point cloud images may also be used to obtain annotation of the images.
The training may include the determination of a loss concerning the determination of the position of reference points.
For example a distance can be determined between a known position of a reference point and the output of the neural network for the same object and the same reference point. This distance (for example L1 or L2) provides a loss and training may be performed until this distance reaches 0.
The training may also include the determination of a loss concerning the determination of the yaw angle.
An angle can be determined as the difference between the obtained yaw angle and a pixel's viewing direction and the cosine and the sine of this calculated angle form a couple and the distance between this couple and the expected couple is determined.
In the above example, the yaw is used as the rotation around the y-axis in the camera coordinate system and there is one value per object. The pixel offset angle is the angle of the ray of light coming from the center of the image acquisition device to the pixel. The viewing angle is the angle between this ray of light and the object, and it can be calculated as the difference between the yaw and the pixel offset.
The loss is calculated, for example, as the L1 distance between a predicted pair of values (p1, p2) and (cos(α), sin(α)), wherein a is the viewing angle. Alternatively, it is possible to use the double of the viewing angle so as to obtain the disambuation described above.
Fisheye cameras may be used.
When the above method is performed on every image coming from these cameras, a 6D pose of a same object can be determined multiple times. It is possible to update a tracked version of this object based on multiple observations at different times and using different cameras.
The disclosure can be used in the context of tracking objects. For example, if i designates an instance such as a vehicle to be tracked, it is possible to determine a multidimensional mean zi and a covariance matrix Zi associated with the variable zi. In fact, the at least one neural network of the disclosure can deliver, for each group of pixels, variance and mean values associated with the group of pixels.
Detection Phase
Consequently, the detections on one image in the context of tracking are approximated as a set of multidimensional normal variables {circumflex over (z)}i˜N(zi,Zi), with i=1, . . . , m.
For instance, using the above method, the vectors z, can be composed of 19 values:
horizontal and vertical coordinates of the 8 corners of the 3D bounding boxes in the image space (i.e. the reference points when using the representation of
the width, the height and the length of the vehicle.
The vectors zi may also be called observations, i.e. the output of the above described method.
It should be noted that the method is not limited to neural networks using 8 reference points, as in the above example. It is also possible to use the representation of
State Prediction Phase
The set of tracked vehicles are described, at time t, with a set of multidimensional normal variables {circumflex over (x)}j˜N(xj,XJ) with j=1, . . . , n. The state of each tracked object (for example vehicle) can be predicted from its previous state at t−1. The prediction phase of an Extended Kalman Filter is used:
x
j
←f(xj)
X
j
←FX
j
F
T
+Q
Wherein f is a state transition model, F is the Jacobian matrix of f, Xj is the covariance matrix associated with xj, and Q is the covariance matrix of the expected noise.
For instance, the state vectors xj can be composed of the following 8 values:
The 3D position of the object,
The width, height, and length of the 3D bounding box associate with this object
The yaw angle of the object.
The speed of the object.
In this example, the state vectors xj represent the means of the estimated vehicle states (3D position, dimensions, speed).
The state transition function f can assume a simple dynamics, with objects moving forward according to their speed. However, more elaborated transition functions can be used.
Observation Prediction Phase
Then it is possible to predict observations yj from the predicted states xj. To do so, the equations in the first half of the update phase of an Extended Kalman Filter are used:
y
j
←h(xj)
Y
j
←HX
j
H
T
+R
With h being the observation model, H is the Jacobian matrix of h, and R is the covariance matrix of the expected noise.
For example, h can project the 8 corners of the 3D bounding box of an object into the space of the image and concatenates its width, height, and length to the result.
Assignment Phase
Then, a combinatorial phase is taking place. The observations {zi}i=1m defined above are assigned to the predicted observations {yj}j=1n also defined above. An assignment from observations to predictions is defined as a partial injective function {1, . . . , m}→{1, . . . , n}. This means that an observation is assigned to at most one prediction, and that one prediction is assigned to at most one observation. The specific assignment a is defined such that the following total cost function is minimized:
The cost function C is defined as the Mahalanobis distance DM between the observation and the prediction.
C(i,j)=Dm(zi,yj)=√{square root over ((zi−yj)T(Zi+Yj)−1(zi−yj))}
In other words, it is the Mahalanobis norm of s=zi−yj. The value Ta is the threshold cost over which no assignment should occur.
It is possible to only use a subset of the values contained in the observations and predictions to perform this assignment phase.
For instance, the 8 corners in the space of the image can be used to assign observations to predictions. Ta can be set to 6. Solving the assignment problem can comprise reducing it to the problem of finding the k-shortest paths in a directed graph. This may be solved using Suurballe's algorithm.
Correction Phase
Subsequently, the difference between the actual observations zi and the predicted observations ya(i) are used to correct the predicted states xa(i). For each i∈Dom(a), we apply the second half of the update phase to an Extended Kalman Filter:
s is the difference between zi, what has been observed, and yj, what has been predicted and therefore is used to correct the state xj.
Reprojection Phase
For each i∉Dom(a), i.e. for each observation that could not be assigned to a known and tracked vehicle, a new vehicle state is created by approximating the inverse of the observation function h. This approximation uses some assumptions about the state of the actual vehicle.
In which h˜ is the approximated inverse of h, p is some prior knowledge, H˜ is the Jacobian matrix of h˜ at zi and p, and P is the covariance matrix of the expected noise. The above equations allow determining a new value xm from a given zi.
For instance, h˜ can approximate the reprojection of the vertical edges of a 3D bounding box using only the predicted height of the vehicle. The position and the orientation of the object can be approximated from there, for example using the method defined before. The prior knowledge p can be set in P to 20 meters per second.
Non-Maximal Suppression Phase
Should any failure happen during the detection phase or during the assignment procedure, it may happen that a same object produces several tracked states. To prevent this a posteriori, a non-maximal suppression is performed over the set of states xj. First, the list of states is sorted in descending order of confidence. Then, for each state xj, all subsequent states xk that verify the following in equation are removed:
D
M(xj,xk)=√{square root over ((xj−xk)T(Xj+Xk)−1(xj−xk))}<Tnms
Tnms is the threshold over the Mahalanobis distance over which two vehicles are considered the same.
It is possible to only use a subset of the values contained in the states vectors to perform this non-maximal suppression phase.
For instance, the 3D position of an object can be used to perform the non-maximal suppression. The threshold Tnms can be set to 6. The confidence measure is in the number of updates recorded over a state.
Should multiple cameras be used, as shown on
Throughout the description, including the claims, the term “comprising a” should be understood as being synonymous with “comprising at least one” unless otherwise stated. In addition, any range set forth in the description, including the claims should be understood as including its end value(s) unless otherwise stated. Specific values for described elements should be understood to be within accepted manufacturing or industry tolerances known to one of skill in the art, and any use of the terms “substantially” and/or “approximately” and/or “generally” should be understood to mean falling within such accepted tolerances.
Although the present disclosure herein has been described with reference to particular embodiments, it is to be understood that these embodiments are merely illustrative of the principles and applications of the present disclosure.
It is intended that the specification and examples be considered as exemplary only, with a true scope of the disclosure being indicated by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
20158613.8 | Feb 2020 | EP | regional |