Next Article in Journal
Autonomous Ground Vehicle Lane-Keeping LPV Model-Based Control: Dual-Rate State Estimation and Comparison of Different Real-Time Control Strategies
Next Article in Special Issue
Fully Automated DCNN-Based Thermal Images Annotation Using Neural Network Pretrained on RGB Data
Previous Article in Journal
Generating Datasets for Anomaly-Based Intrusion Detection Systems in IoT and Industrial IoT Networks
Previous Article in Special Issue
Experimental Comparison between Event and Global Shutter Cameras
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Shape-Based Alignment of the Scanned Objects Concerning Their Asymmetric Aspects

1
Department of Applied Informatics, Faculty of Mathematics, Physics and Informatics, Comenius University, Mlynska Dolina, 842 48 Bratislava, Slovakia
2
ME-Inspection SK, Drobneho 25A, 84101 Bratislava, Slovakia
*
Author to whom correspondence should be addressed.
Sensors 2021, 21(4), 1529; https://doi.org/10.3390/s21041529
Submission received: 12 January 2021 / Revised: 15 February 2021 / Accepted: 19 February 2021 / Published: 23 February 2021
(This article belongs to the Collection Sensors and Data Processing in Robotics)

Abstract

:
We introduce an integrated method for processing depth maps measured by a laser profile sensor. It serves for the recognition and alignment of an object given by a single example. Firstly, we look for potential object contours, mainly using the Retinex filter. Then, we select the actual object boundary via shape comparison based on Triangle Area Representation (TAR). We overcome the limitations of the TAR method by extension of its shape descriptor. That is helpful mainly for objects with symmetric shapes but other asymmetric aspects like squares with asymmetric holes. Finally, we use point-to-point pairing, provided by the extended TAR method, to calculate the 3D rigid affine transform that aligns the scanned object to the given example position. For the transform calculation, we design an algorithm that overcomes the Kabsch point-to-point algorithm’s accuracy and accommodates it for a precise contour-to-contour alignment. In this way, we have implemented a pipeline with features convenient for industrial use, namely production inspection.

1. Introduction

Laser profile sensors [1,2] provide very accurate depth maps at a very reasonable speed suitable for a wide range of useful tasks. Their typical final output is a 2D array containing distances from the sensor to the scanned area for each point in a 2D grid. Each such sensor measures a limited range; thus, some values may be non-measured. We can view this data as an image in which pixel values are float numbers (z-coordinate) or not-a-numbers. On the other hand, we can display them also as a 3D point-cloud. For any reasonable use, we have to process the data by various methods of computer vision. We introduce one such processing pipeline in this paper.
Object recognition and alignment [3] are tasks frequently solicited in various domains of industry [4]. Having a single template, we have to identify the corresponding object in a scanned depth map and calculate the transform that aligns the found object into a default position, orientation and size given by the template. The recognized object is potentially displaced, rotated, or scaled; thus, we aim to find an accurate rigid affine transform [5]. Then we use the transform for a particular task like quality inspection [6,7,8]. We typically need to align objects like various housings, holders, straps, teeth wheels and others. After alignment, we can check their dimensions, completeness of details (screws, letters), or defects (missing areas, extra areas).
Though we can employ various methods for implementing our processing pipeline, it is challenging to look for a general solution for real industrial needs. The available strategies suppose substantial limitations to the number or shape of the scanned objects [9]. Concerning a general-purpose, no well-known image registration method has been found that is suitable for our purposes. The classic approach of the phase correlation [10] is fast (thanks to the Fast Fourier Transform algorithm) but limited to the same size and rotation, while its improvements [11] are not sufficiently accurate. Methods based on image features (SIFT, SURF, ORB [12]) are not suitable for our purpose at all. Though [13] employs them for shape-based inspection under very similar circumstances, they are not general enough. These methods do not work for fade objects that do not provide enough key-points [14]. Finally, the Efficient Correlation Coefficient (ECC) [15] can gradually find the transform of a template image onto a part of a given image, but for more rotated objects with complicated shapes, it gets stuck in a local minimum and does not reach the optimal alignment. Moreover, using ECC, we have to estimate the initial object position with another method.
During our technology pool, we found the shape-based methods much more applicable to our mission. In [16], the processing pipeline for calculating object position and distance successfully employed the Hough transform [17], applied after the Gaussian filter, edge detection and threshold-based segmentation. In [18], a similar processing pipeline consisted of binarization, centroid location with the linear displacement calculation, edge detection and angular displacement calculation is also shape-based. The pipeline presented in [19] based on the Farthest Point Angle descriptor contains shape representation with contour, signature construction, shape description using Fourier Transform, shape toning and ranking.
The best shape-based method we found is Triangle Area Representation (TAR) [20,21,22]. It is based on the Dynamic Space Warping (DSW) algorithm [23]. TAR provides not only the distance between two contours concerning their similarity but also their point-to-point pairing. Thus, we can directly employ its output as input for their alignment. This method rarely occurs in industrial applications, but some applications have already existed. Reference [24] measured geometrical properties of profiled fibers. Reference [25] implements fiber classification. These applications deal with inspecting a concrete object, while our approach is general—we do not know what particular objects we process.
However, the shape-based methods also have limitations we need to overcome. Frequently, the outer contour of objects is not sufficient for their proper alignment. Even when shapes align correctly, the inner areas can align in the wrong way if we process symmetric objects with some asymmetric aspects. Some specific shape descriptors already designed can solve this problem. The Hybrid Shape Descriptor (HSD) [26,27] is based on circular areas covering the object. The inner part of objects is partially concerned with the shape descriptor presented in [28]. In general, these descriptors are less efficient, and require a perfect image binarization. That makes them not applicable for our purposes. Therefore we aim to use TAR and improve it by a solution to this problem. We follow the idea from [29], which presents an approach to the shape descriptor extension. They extend the shape descriptor by the texture and color, so we cannot employ their approach directly for our depth maps. However, their success indicates that such extensions can solve this problem.
Since TAR does not apply directly to images, we need another method for finding potential object contours. That is also not a trivial task. The most common edge detectors are not suitable here because the edges they provide are not always continuous. We have to binarize the image to ensure the continuity of contours. When we scan objects lying on the floor outside the sensor range, the binarization is straightforward—we distinguish just the measured and non-measured values. However, we need a sophisticated approach when the scanner detects one object lying on another one or the floor. No local thresholding method, like Otsu, MaxEntrophy, Niblack, Sauvola or others [30], is perfect. However, we can successfully use an arbitrary one if we preprocess the image with the Retinex filter [31]. The output from the filter we binarize by the IsoData [32] local thresholding approach. Remarkably, methods that do not require continuity of edges have already existed like Contour Segment Context (CSC) [33]. However, phantom detections’ danger is serious when we are concerned with more kinds of objects that may or may not be present in the scanned data. Having a single edge, we can eliminate phantom detection by its shape. But when we have more ones per object, their mutual placement can generate phantoms.
Finally, having point-to-point pairing, we had to calculate the rigid affine transform that aligns the recognized object contour onto the template object contour. We expected that it is enough to call the Kabsch algorithm [34] for that (e.g., [35] employs it for the same purpose), but we encountered troubles caused by the fact that the contours are sequences of the sampled points. We are not looking for a point-to-point transform but a contour-to-contour one. And unlike typical contour-to-contour alignment algorithms [36], we have to preserve shape. In [37], the proper algorithm is designed for 2D; however, we need 3D.Therefore we had to design our solution, more sophisticated than the Kabsch algorithm. A similar problem with alignment accuracy has appeared in [38]. Our solution employs a similar idea to that in [39].
In this paper, we present our solution for the complete process pipeline to the above problem. Its quality is good enough for use in practice. Our solution stems from the composition of existing methods. Besides their integration, our contribution is their improvement by resolving issues that are beyond their capacity. We present it in the next section. We gradually describe the processing pipeline, starting with contour detection, following the shape comparison and its extension introduced by us, and ending with our alignment algorithm. Further sections present results and discuss their quality and potential.

2. Materials and Methods

We designed a method for the object recognition and alignment task concerning inspection purposes (Figure 1). The process’s input is a depth map provided by the laser profile sensor. Its output is an affine transform that aligns the recognized object to a standard position. We have a database of templates that describes a set of the inspected items, created by manual selection of their contours on scans made when they are in the standard position. During the object identification, we processed the measured data as the 2D array of measured elevations in which some points can be missing. After the object recognition, we considered the data a 3D point-cloud, in which alignment we find (Figure 1).
Our processing pipeline for object recognition and alignment is as follows (Figure 2). In the beginning, we scanned the template object in its standard position and rotation. We process the scanned depth map to a list of present contours and offer them to the user. The processing resides in the point-cloud rendering to the 2D image, its binarization and contour finding. Since we can use more binarization methods, we also have to address the removal of duplicates. The user selects one contour that corresponds to the object boundary. Then, we process the selected part of a template and store it for later use. At first, we sampled its shape by a fixed number of points, so we get indices that we could use to index both the 2D contour and the corresponding points of the 3D point-cloud. Secondly, we calculated the shape descriptor from the indexed 2D points. Thirdly, we described the inner part of the object by the so-called extension. Later we scanned scenes with translated and rotated objects that the template represents. We processed the scanned depth map in an analogical way and compared each found contour with the template. The comparison does not only identify the demanded item, but we also get a pairing of its outline points with the outline points of the template. Then we could use the pairing for the best matching item for the calculation of the alignment transform. If we get more candidates for the best matching, we select one of them, following the extension. Finally, we aligned the scanned depth map by the calculated transform.
The mentioned processing relies on several separated methods applied gradually. At first, we have to find contours in the scanned depth map. Then we have to implement their shape based comparison, which can also provide their pairing. Finally, we have to turn the pairing to the alignment transform. We describe these three steps in the following subsections.

2.1. Finding Contours

Contours we are looking for must be closed and continuous. We can grant this feature if we turn the scan into a binary image and process it by the traditional contour finding algorithm [40]. We are concerned with more methods of binarization, so we put together more sets of found results. We rely on two approaches. The main one employs the Retinex filter [31]. The filter turns an image into a logarithm of the ratio between pixel value and its average vicinity value. The average utilizes the Gaussian filter of a bigger size that can be effectively calculated by the circular convolution. That is fast due to the employment of the Fast Fourier Transform algorithm. Thus, the Retinex filter R of image I is calculated as follows:
R ( I ) = log I G I = log I log G I = log I log F 1 ( F ( G ) F ( I ) ) ,
where G is the 2D Gaussian filter, *, is the convolution operator and F denotes the Fourier Transform.
The Retinex filter does not binarize images but turns the majority of pixel values to very low or very high. Thus, it is easier to binarize its output by a suitable threshold; we employ IsoData local threshold [32] for this job (Figure 3).
Though the Retinex filter nicely preserves contours, it also generates phantom ones at each flat area in which there is another smaller and higher object. Thus, the stepped pyramid has not only square outlines but also volatile ones at each flat step. However, concerning the contours hierarchy, it is easy to ignore them.
There is just one case in which the Retinex filter fails. That is a scan of a single object, which has high and low parts. If there is also a floor, the filter works. However, without the floor, it disintegrates the scanned object. Fortunately, in this case, we can find the proper contour by a straightforward binarization method, which concerns just the measured and non-measured values.
Finally, we join the results of the two methods mentioned above. In the case that we present the found contours to the user for the selection of one corresponding to the represented object, we have to also solve the removal of duplicates. We resolved this by rendering the found contours in downsampled images and comparison of the binary masks. See Algorithm 1.
Algorithm 1 Contours finding algorithm
1:
procedure FindContours(I)                     ▷I is a depth map
2:
   C o n t o u r s { }                ▷ list of closed 2D point sequences
3:
  Add contours from IsoData(Retinex(I)) to C o n t o u r s
4:
  Add contours from IsMeasured(I) to C o n t o u r s
5:
  Remove duplicates in C o n t o u r s                    ▷ optional
6:
  return I ( C o n t o u r s )           ▷ return list of closed 3D points sequences

2.2. Shape-Based Comparison

Our approach to shape comparison is based on TAR [20]. Each contour in a depth map is a sequence of adjacent 2D points. The amount of points varies, but we sample them to a fixed number. It is reasonable to be concerned with l points, where l equals 100 or 200. More points better describe the shape; fewer points enable fast processing. We process the sampled contour to the so-called TAR descriptor—a set of sequences of the normalized triangle areas. Each one contains areas of triangles in which vertexes are points of the contour. The second and third vertexes are the left and right neighbors of the first vertex. For the first sequence, the distance between the first vertex and its neighbors is one. For the second one, it is two, and so on. The usual number of such sequences t is ten. Thus, the TAR descriptor forms a matrix of t × l of values. The triangles’ area can be positive or negative, depending on the angle’s reflexivity at the first vertex. We divide it by the sum of the areas’ absolute values, so it is normalized to the range from 1 to 1. Thus, we have t values forming a vector for each point on the sampled contour that describes the local shape. As a result, we can compare the shape at two points by calculating the Euclidean distance between their corresponding vectors. See Figure 4 and Algorithm 2.
Algorithm 2 Calculation of the TAR descriptor
1:
procedure CalculateTAR( c o n t o u r )         ▷ c o n t o u r is a sequence of 3D points
2:
   i n d i c e s Sample ( c o n t o u r , l )               ▷ select l equidistant points
3:
   p o i n t s c o n t o u r [ i n d i c e s ]
4:
  Allocate T A R                           ▷ matrix t × l
5:
  for i 1 to t do
6:
    for k 0 to l 1 do
7:
      T A R i 1 , k TriangleArea ( p o i n t s ( k i ) % l , p o i n t s k , p o i n t s ( k + i ) % l )
8:
  return T A R , i n d i c e s              ▷ return TAR descriptor and indices
The calculation of TAR descriptors is fast, but their comparison is time consumable; therefore, we have to sample to compare contours. We performed it using the cyclic DSW algorithm [23]. The cyclic DSW is called standard DSW (non-cyclic version) for each possible shift between compared descriptors. We can shift just the second descriptor, so DSW is called l times. DSW compares the two descriptors ( r = r 0 , r 1 , , r l 1 and s = s 0 , s 1 , , s l 1 where r i and s i are vectors of length t) and returns minimal distance and point-to-point pairing. If we imagine the best pairing, there is a shift that pairs the first points of r with the first point of the shifted s. Therefore we can investigate just pairings starting at the beginning of the first descriptor and the shifted second descriptor. The DSW algorithm is a kind of dynamic programming, so it gradually calculates table D i , j containing the minimal distance between the first descriptor from beginning to position i and the shifted second descriptor from beginning to position j. It employs the following formula:
D 0 , 0 = r 0 s 0
D i , j = m i n ( D i 1 , j 1 , D i 1 , j , D i , j 1 ) + r i s j ,
where the norm is L1.
Since we can suppose that sampling of contours causes just a little variation, it is enough to evaluate D values close to diagonal. Therefore, we consider parameter w, called a window, which specifies that we examine D i , j for i w j i + w and set other values to infinity.
Finally, D l 1 , l 1 tells us the resulting minimum. Then, we can find a path from ( l , l ) to ( 0 , 0 ) , which corresponds to its gradual calculation. Then, we take each pair from the way to the resulting pairing (in the opposite order). As a result, the pairing does not have exactly l pairs, and some points from one contour can pair with more points in the second contour, but in practice, this is still a piece of handy information about their alignment.
We can now evaluate the convergence rate of the DSW algorithm as O ( t w l ) ; thus, for the cyclic DSW, it is O ( t w l 2 ) .
For most shapes, the integration of results for individual shifts is easy—we select the minimum. However, for symmetric shapes, we get the (almost) same minimum more times. Rectangles and ovals give the minimum two times, squares four times and circles l times. If the objects have symmetric not only contour but also the inner area, we can return anyone. However, when their inner area is asymmetric—for example, because of holes—we encounter a limitation of shape-based methods. Imagine, for instance, a square-shaped component with holes in two corners (Figure 5) or a teeth wheel with a hole in one tooth. Such objects provide us more choices on aligning them with their templates; however, only one of them is correct.
Fortunately, TAR is suitable for an extension we have invented to solve this problem. We added one additional sequence to the TAR descriptor that describes the inner area of the object. It specifies the normalized area of the triangle with vertexes in left and right neighbors for the last TAR sequence and the center of mass. Of course, we regard only the area covered by the object. We calculated it from the binarization output. Though the Retinex filter is not suitable for this (because of phantom holes inside the object), we can employ the less sophisticated method, which usually cannot find the contour, but sufficiently describes the inner part. In this case, the areas are always positive, so we normalize them into the interval from 0 to 1 (Figure 6). See Algorithm 3.
Algorithm 3 Calculation of the TAR extension
1:
procedure CalculateExtension( c o n t o u r , i n d i c e s , d e p t h M a p )
2:
   m a s k isMeasured ( d e p t h M a p )
3:
   p o i n t s c o n t o u r [ i n d i c e s ]       ▷ the same points as for the TAR descriptor
4:
   c e n t e r Average ( p o i n t s )
5:
  Allocate E x t e n s i o n                      ▷ vector of l values
6:
  for k 0 to l 1 do
7:
     t r i a n g l e m a s k & Triangle ( p o i n t s ( k i ) % l , c e n t e r , p o i n t s ( k + i ) % l )
8:
     E x t e n s i o n k Area ( t r i a n g l e )
9:
  return E x t e n s i o n               ▷ return the TAR descriptor extension
The extension enables us to select the proper minimum and pairing. Of course, we have to assume that the minima can vary a bit. Therefore we examine all minima close enough to the absolute minimum. However, then we would process for each demanded minimum also values returned for similar shifts. We have to use non-maximum suppression for their elimination. In this way, we have extended the TAR method to find the right point-to-point pairing even for objects with symmetric shapes and other asymmetric aspects. See Algorithm 4.
Algorithm 4 Shape comparison algorithm
1:
procedure Compare( r , s )        ▷r and s are extended TAR descriptors with length l
2:
   R e s u l t s { }
3:
  for k 0 to l 1 do
4:
    Call DSW ( r T A R , shiftBy ( s T A R , k ) ) ; it returns distance d and pairing P
5:
    Add ( d , P , k ) to R e s u l t s
5:
  
6:
   d m i n min { d ( d , P , k ) R e s u l t s }           ▷ Find the minimal distance
7:
   M i n i m a { ( d , P , k ) ( d , P , k ) R e s u l t d d m i n + ϵ }
8:
   M i n i m a NonMaximumSuppression ( M i n i m a )         ▷ promising results
9:
   b e s t a r g m i n { r e x t e n s i o n s e x t e n s i o n ( d , P , k ) M i n i m a }
10:
   ( d , P , k ) M i n i n a [ b e s t ]
11:
  return d , shiftBy ( P , k )       ▷ return the minimal distance and the best pairing
Of course, we can use this mechanism not only for contours comparison but also for object recognition. We process the scan to a set of contours and compare each one with the template. For the demanded object, the mechanism returns a distance close to zero. For others, we get significantly higher values.

2.3. Alignment Transform

Seemingly, having the best point-to-point pairing, we can get a rigid affine transform that aligns the recognized object straightforwardly. Nothing could be further from the truth. Though we have a standard algorithm that calculates the best transform for a set of pairs of points, its results are insufficient. The problem is that the mentioned Kabsch algorithm [34] is a least square method that minimizes the sum of distances between the transformed origin points and the _target points. However, our mission is quite different. Deviations between points lying on the contour are much better than deviations oriented perpendicularly. The contour sampling has just a little impact on the TAR method. However, here it has significant and destructive effects (Figure 7b).
We have found that we can use the Kabsch algorithm as an appraise that we can improve iteratively. The idea is the following. Let the pairing provided by the TAR method contains n pairs of points (we notice that n can be slightly higher than l). We will represent it as three lists of n elements—the original points p, _target points q, and indices k such that p i pairs with q k i . Then we apply the Kabsch algorithm, which gives us a transform T that transforms p i to T ( p i ) . Now can investigate what q j is closest to T ( p i ) . If the algorithm works for us, j = k i . However, there can be a small difference from the beginning, and j will differ from k i . It will not differ too much; it will be k i + u or k i u for a little u (this feature enables us to find it efficiently). The difference indicates that our pairing is not perfect. So we adjust the pairing by assigning k i : = j . And then we repeat the process until we can improve neither index k i . See Algorithm 5.
Algorithm 5 Alignment algorithm
1:
procedure Align( a , b )       ▷a and b are sequences of 3D points of the same length
2:
  Start with the initial pairing a i with b i for all i
3:
  repeat
4:
    Call the Kabsch algorithm for the current pairing. It returns a transform T
5:
    Transfrom points a to points c T ( a )
6:
    Calculate a better pairing: pair a i with b j that is the closest b point to c i
7:
  until the pairing is not improved
8:
  return T          ▷ T is a matrix 3x4 representing a rigid affine transform
Our iterative algorithm is slower than the Kabsch algorithm, which we usually call for real data up to twenty times. However, it provides excellent alignment (Figure 7c). It is not trivial to tell how much it is better. If we have the sum of Euclidean distances of the transformed and _target points, it is less (of course) for the Kabsch algorithm because it is optimal for point-to-point matching. But, this is not the measure we want to minimize. It is better to define the contour-to-contour alignment quality by overlapping areas surrounded by the transformed (A) and _target (T) points.
E r r o r = 1 | A T | | A | .
While the Kabsh algorithm error for the sample in Figure 7 is 3.7%, we can decrease it to 0.9% by our method.

2.4. Integration

We integrate the approaches mentioned above in a system relatively quickly, but still, we have to finalize some issues. We need to answer the question—what information we have to store as the template representing the demanded objects. Answering it, we can prefer minimal data to be stored or the most efficient calculation. The key reason for following the second approach is that it is good to keep all points of the found contour for its later presentation to the user. These data overwhelm the rest; hence it is reasonable to save all the stuff. Thus, the template contains the following:
  • n adjacent points of the found contour, including their pixels’ position and value (we set this data as 3D points).
  • l indices to the above list that sample the contour for the shape representation purposes
  • TAR descriptor t × l values from 1 , 1 describing the shape
  • TAR extension l values from 0 , 1
The overall processing pipeline joins the above-methods. Its summary is in Algorithm 6.
Algorithm 6 Object recognition and alignment
1:
procedure PrepareTemplate(A)                      ▷A is a depth map
2:
   C o n t o u r s A FindContours ( A )
3:
   C o n t o u r A Select ( C o n t o u r s A )            ▷ Let the user select one contour
4:
   D e s c r i p t o r T A R A , I n d i c e s A CalculateTAR ( C o n t o u r A )
5:
   D e s c r i p t o r E x t e n s i o n A CalculateExtension ( C o n t o u r A , I n d i c e s A , A )
6:
  SaveTemplate ( C o n t o u r s A , I n d i c e s A , D e s c r i p t o r T A R A , D e s c r i p t o r E x t e n s i o n A )
7:
procedure UseTemplate(B)                        ▷B is a depth map
8:
  LoadTemplate ( C o n t o u r s A , I n d i c e s A , D e s c r i p t o r T A R A , D e s c r i p t o r E x t e n s i o n A )
9:
   P o i n t s A C o n t o u r A [ I n d i c e s A ]
10:
   C o n t o u r s B FindContours ( B )
11:
   D i s t a n c e m i n
12:
  for C o n t o u r B C o n t o u r s i B do              ▷ test each found contour
13:
     D e s c r i p t o r T A R B , I n d i c e s B CalculateTAR ( C o n t o u r B )
14:
     D e s c r i p t o r E x t e n s i o n B CalculateExtension ( C o n t o u r B , I n d i c e s B , B )
15:
     P o i n t s B C o n t o u r B [ I n d i c e s B ]
16:
     D i s t a n c e , P a i r i n g Compare ( D e s c r i p t o r B , D e s c r i p t o r A )
17:
    if D i s t a n c e < D i s t a n c e m i n then
18:
       D i s t a n c e m i n D i s t a n c e
19:
       P a i r i n g m i n P a i r i n g
20:
       P o i n t s m i n P o i n t s B
21:
  if D i s t a n c e m i n then
22:
     T Align ( P o i n t s m i n , P o i n t s A [ P a i r i n g m i n ] )
23:
    return T                    ▷ return transform that align B to A

3. Results

We have tested our processing pipeline on several objects (precisely seven), having a few scans (precisely one time seven, four times five, and two times two) made under different conditions per each type. We selected one scan as a template and tested it with other ones. We tested the shape comparison mechanism per each type, having from one to ten contours per scan. We also tried to overcome our dataset’s small size by testing the shape comparison for all contours in the whole dataset, each to the other. In this way, we tried hundreds of comparisons, all successfully. The maximal distance between the same object shapes was smaller than the minimal distance between them and other objects’ contours for each tested item.
We present the results for an example object in Figure 8 and more scans and objects in Figure 9. Table 1 presents quantitive results related to the shape comparison. We have tested our solution’s ability to recognize our object by the following distance of its shape to the samples’ shape of the same and different types. Hence, the first distance is smaller than the second ones, the shape comparison is correct. This fact is visible in the table—diagonal values are lower than others. Table 2 presents quantitive results related to the shape alignment quality. On average, we get an error of 0.35%. Even this deviation corresponds mainly to the discretization of data during the evaluation of the error and the fact that the actual data contours are not perfectly smooth. For comparison, the average error of alignment with itself is 0.20%. The processing time (mentioned in the same table) depends on the input data size, density, and contours. On a single-core CPU, we get e.g., 0.2 s, 0.3 s, or 0.7 s depending on the mentioned parameters. Moreover, the DSW algorithm, which is the most consuming part, can be implemented on GPU or employ parallelism on more CPU cores.
Following the quantitative evaluation in [27], we have tested our approach on the Kimia99 dataset [41,42]. The dataset contains various shapes that we have used as molds for the generation of depth maps. We randomly rotated and translated each depth map and tried to align it with the original one. Then we evaluated the error by the overlapping of the original and the aligned object. At first, we have checked that we get proper point-to-point pairing for 100% of samples. Then we evaluated the error for the alignment result. We get an error of 0.0045% (the depth maps are artificial; thus, we get a much lower error than on actual scans). If we replace our alignment algorithm with the classic approach, that is, with the single call of the Kabsch algorithm, we get a slightly higher error of 0.0086%. It means that for most of the samples, the Kabsh algorithm is sufficient, and there is no difference between its output and the output of our tuned version. Still, it sometimes exhibits significant error (see Figure 7), which is a big limitation for its industrial use. Therefore our tuned solution is much more applicable in practice.

4. Discussion

We live in an era of machine learning [43]. However, looking for a processing pipeline for a particular problem solicited from the industry, we often lack a larger dataset. Also, in our case, the requirement was to operate with a single example. Such conditions give a chance for the further development of classic methods. We had to rely on the correctness of our algorithms instead of statistical validation.
We had a problem clearly defined in the beginning, and we have been looking for technology for which it is tractable. We find that shape-based methods are most applicable and, among them, we found TAR as the best solution. The usage of existing methods appeared to be able to solve simple cases. Then we have to tackle problems that occurred in advanced cases.
We consider that the objects are products, and the aim of their alignment is mainly their quality inspection. We appreciate the preservation of shape during alignment, since, just in this case, we can compare the aligned object with the prototype looking for defects. It is an opposite requirement to that of a lot of applications that require accommodation of the compared contours. Of course, our approach allows the recognition of moderate deviations from the template contour. However, this is given just by a non-zero limit in the distance between TAR descriptors of the compared shapes.
We present our contribution to the current state-of-the-art in Table 3. We have selected several approaches with a similar mission. All of them are based on the shape comparison using various shape descriptors. Two of them employs TAR as we do. We hired comparison features of individual approaches relative to object recognition and alignment—the number of supported objects and their types, whether they can overlap, whether the supported shapes are simpler or complicated, the danger of the phantom detections. Of course, we also focused on the approaches’ ability to solve the problem with asymmetric aspects of the symmetric objects. Finally, we followed the precision of alignment. Our solution positively supports most of these features. Just regarding the overlapping, we are limited. Our items can overlap, but their contours must not. That is good enough for the concerned application purposes. However, we cannot process two pieces that overlap as the CSC can. On the other hand, using CSC, there is a significant danger of phantom detections. Thus our approach is more convenient for industrial applications.
A fundamental boundary of our approach is that the scanned objects must not overlap by their contours. One item can stand on top of another, but not at its edge. From limitations that we have not expected but found, we mention the quality of scans. In one case, we failed to find the proper contour. But indeed, the scanned data’s shape differed from reality. In practice, we had to consider that the laser profile sensor can fail in this way. Another limitation is the setup of data binarization. It is possible to volume for a particular object type, but any universal configuration cannot grant that the binarization is always successful. If we succeed in having the object contour in the binarized data, the rest of the process is thriving. A limitation also resides in the speed of processing. The cyclic DSW algorithm is quite time consumable and confines the number of the points that sample the contour. A reasonable number of sampling points is 200. It is also sufficient for complicated shapes, but it is a limitation.
Further development of our solution is possible mainly through the inclusion of other methods for contour finding. That is a part of our approach that could be improved by methods of deep learning. We could even consider an automated generation of a dataset using a generator of various solids and their processing by contour finding we have introduced in this paper.
An improvement is also possible in binarizing the object’s inner area for extension of the TAR descriptor. We rely upon that holes in the scanned item will contain some non-measured values. This assumption usually holds for holes. But the description of the inner area could be more accurate if we can also include bulges and cavities.
On the other hand, further improvement of the alignment algorithm is not very probable.

5. Conclusions

We have designed, implemented, tested and evaluated a processing pipeline for object recognition and alignment. We have combined several existing methods, contributed by overcoming their limitations, and created an integrated system with applicable quality for industrial purposes and potential for competitive products. We resolved all issues successfully, and our industrial partners found our results to be plausible. We summarize our contribution in three points:
  • We have improved the TAR method by extending the TAR descriptor and making it operational for objects with symmetric shapes and other asymmetric aspects.
  • We have designed an algorithm for contours alignment (preserving their shape), which utilizes the Kabsch algorithm and provides better results.
  • We have integrated several methods into an operational processing pipeline.
Our processing pipeline is a module dedicated to usage within integrated inspection systems. Thanks to the module, such systems can perform quality tests on the aligned object straightforwardly, while it would be difficult to achieve the same with the measured data.
Our solution operates in real-time, that is, time consumption enables us to process each product on the production line. Our solution is also suitable for edge devices; we could even embed it into the laser profile sensor. Such intelligent sensors can directly send the quality test results to the production control system, simplifying inspection implementation.
We implemented our solution using the OpenCV Library [44]. We have used programming languages C++ and Python. We share selected codes of this project at GitHub (https://github.com/andylucny/ObjectAlignmentViaTAR).

Author Contributions

Conceptualization, V.D.; methodology, V.D.; software, M.R., V.D., G.K. and A.L.; validation, G.K.; formal analysis, A.L.; investigation, G.K.; resources, A.L.; data curation, A.L.; writing—original draft preparation, A.L.; writing—review and editing, A.L.; visualization, A.L. All authors have read and agreed to the published version of the manuscript.

Funding

VEGA grant number 1/0796/18 partially funded this research.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

The data presented in this study are available at https://github.com/andylucny/ObjectAlignmentViaTAR. We have also employed the publicly available dataset KIMIA99 that can be found at https://github.com/mmssouza/kimia99.

Acknowledgments

This research stems from the cooperation between the Department of Applied Informatics at the Comenius University and the ME-Inspection SK. The authors thank ME-Inspection and its general director, Marian Sramek, for testing data and other resources. The kind supervision of Igor Farkas from the Department of Applied Informatics, who inspired this paper’s preparation, is also appreciated.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Giesko, T.; Zbrowski, A.; Czajka, P. Laser profilometers for surface inspection and profile measurement. Probl. Eksplotacji 2007, 10, 97–108. [Google Scholar]
  2. Suh, Y.S. Laser Sensors for Displacement, Distance and Position. Sensors 2019, 19, 1924. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  3. Benjamin, D. Object Alignment and Detection. Ph.D. Thesis, Technische Fakultätder Albert-Ludwigs-Universität Freiburg im Breisgau, Freiburg im Breisgau, Germany, 2017. [Google Scholar]
  4. Dominguez, E.; Spinola, C.; Luque, R.M.; Palomo, E.J.; Muñoz, J. Object recognition and inspection in difficult industrial environments. In Proceedings of the IEEE International Conference on Industrial Technology (ICIT), Mumbai, India, 15–17 December 2006. [Google Scholar]
  5. Aubry, M. Representing 3D Models for Alignment and Recognition. Ph.D. Thesis, Ecole Normale SupéRieure, Paris, France, 2015. [Google Scholar]
  6. Syberfeldt, A.; Ekblom, T. Improved Automatic Quality Inspections through the Integration of State-of-the-Art Machine Vision and Collaborative Robots. In Proceedings of the 17th International Conference on Manufacturing Research, Incorporating the 34th National Conference on Manufacturing Research, Belfast, Northern Ireland, 10–12 September 2019; pp. 107–112. [Google Scholar]
  7. Yang, Y.; Miao, C.; Li, X.; Mei, X. On-line conveyor belts inspection based on machine vision. Opt.-Int. J. Light Electron Opt. 2014, 125, 5803–5807. [Google Scholar] [CrossRef]
  8. Djurdjanovic, D.; Mears, L.; Niaki, F.A.; Haq, A.U.; Li, L. State of the Art in Process, System and Operation Level Control in Modern Manufacturing. J. Manuf. Sci. Eng. 2018, 140, 61010. [Google Scholar] [CrossRef]
  9. Turgut, K.; Dutagaci, H.; Soyleyici1, C.; Secil, S.; Ozkan, M.; Parlaktuna, O.; Parlaktuna, M. Method for Determining Local Coordinate Frames Attached to Objects by a Laser Profile Sensor in Industrial Robot Workspaces. In Proceedings of the IEEE International Conference on Autonomous Robot Systems and Competitions (ICARSC), Coimbra, Portugal, 26–28 April 2017; pp. 260–265. [Google Scholar]
  10. Kuglin, C.D.; Hines, D.C. The Phase Correlation Image Alignment Method. In Proceedings of the IEEE International Conference of Cybernetic Society, New York, NY, USA, 8–11 April 1975; pp. 163–165. [Google Scholar]
  11. Sarvaiya, J.N.; Patnaik, S.; Kothari, K. Image Registration Using Log Polar Transform and Phase Correlation to Recover Higher Scale. J. Pattern Recognit. Res. 2012, 10, 90–105. [Google Scholar] [CrossRef]
  12. Rublee, E.; Rabaud, V.; Konolige, K.; Bradski, G.R. ORB: An efficient alternative to SIFT or SURF. In Proceedings of the International Conference on Computer Vision (ICCV), Barcelona, Spain, 6–13 November 2011; pp. 2564–2571. [Google Scholar]
  13. Chen, H.; Cui, Y.; Qiu, R.; Chen, P.; Liu, W.; Liu, K. Image-Alignment Based Matching for Irregular Contour Defects Detection. IEEE Access 2018, 6, 68749–68759. [Google Scholar] [CrossRef]
  14. Jakab, M.; Benesova, V.; Racev, M. 3D object recognition based on local descriptors. In Proceedings of the SPIE Intelligent Robots and Computer Vision XXXII: Algorithms and Techniques, San Francisco, CA, USA, 9–10 February 2015; p. 94060L. [Google Scholar]
  15. Evangelidis, G.D.; Psarakis, E.Z. Parametric Image Alignment Using Enhanced Correlation Coefficient Maximization. IEEE Trans. Pattern Anal. Mach. Intell. 2008, 30, 1858–1865. [Google Scholar] [CrossRef] [Green Version]
  16. Xiong, J.; Liu, G.C.; Pi, Y.P. Increasing stability inrobotic GTA-based additive manufacturing through opticalmeasurement and feedback controlRobot. Comput. Intergrated Manuf. 2019, 59, 385–393. [Google Scholar] [CrossRef]
  17. Kassim, A.A.; Tan, T.; Tan, K.H. A comparative study of efficient generalised Hough transform techniques. Image Vis. Comput. 1999, 17, 737–748. [Google Scholar] [CrossRef]
  18. Hossain, M.S.; Mireles, J.; Morton, P.; Lin, Y.; Terrazas, C.A.; Wicker, R.B. Part re-registration during process interruption of electron beam melting additive manufacturing. Int. J. Adv. Manuf. Technol. 2018, 96, 337–344. [Google Scholar] [CrossRef]
  19. Mani, M.R.; Varma, G.P.S.; Potukuchi, D.M.; Satyanarayana, C. Design of aNovel Shape Signature by Farthest Point Angle for Object Recognition. IJ Image Graph. Signal Process. 2015, 7, 35–46. [Google Scholar]
  20. Alajlan, N.; El Rube, I.; Kamel, M.S.; Freeman, G. Shape Retrieval Using Triangle-Area Representation and Dynamic Space Warping. Pattern Recognit. 2007, 40, 1911–1920. [Google Scholar] [CrossRef]
  21. Alajlan, N. Fast shape matching and retrieval based on approximate dynamic space warping. Artif Life Robot. 2010, 15, 309–315. [Google Scholar] [CrossRef]
  22. Hu, D.; Huang, W.; Yang, J.; Shang, L.; Zhu, Z. Shape matching and object recognition using common base triangle area. IET Comput. Vis. 2015, 9, 769–778. [Google Scholar] [CrossRef]
  23. Wang, K.; Gasser, T. Alignment of curves by dynamic time warping. Ann. Stat. 1997, 25, 1251–1276. [Google Scholar]
  24. Tang, L.P.; Zeng, P.F.; Wu, X.Y.; Xu, B.G. Triangle area representation for profiled fiber shape. J. Donghua Univ. 2010, 3, 293–299. [Google Scholar]
  25. Guo, X.; Ouyang, W.; Xu, B. Shape recognition of profiled fibers usingtriangle-area representation. Meas. Sci. Technol. 2013, 24. [Google Scholar] [CrossRef]
  26. Xu, H.; Yang, J.; Tang, Y.; Li, Y. A Hybrid Shape Descriptor for Object Recognition. In Proceedings of the 2015 IEEE Conference on Robotics and Biomimetics, Zhuhai, China, 6–9 December 2015; pp. 96–101. [Google Scholar]
  27. Xu, H.; Yang, J.; Shao, Z.; Tang, Y.; Li, Y. Contour Based Shape Matching for Object Recognition. In Proceedings of the International Conference on Intelligent Robotics and Applications, Tokyo, Japan, 22–24 August 2016; pp. 289–299. [Google Scholar]
  28. Shi, Y.; Wang, G.; Wang, R.; Zhu, A. Contour descriptor based on space symmetry and its matching technique. Optik 2013, 124, 6149–6153. [Google Scholar] [CrossRef]
  29. Yuvaraj, D.; Sivaram, M.; Karthikeyan, B.; Abdulazeez, J. Shape, Color and Texture Based CBIR System Using Fuzzy Logic Classifier. Tech Sci. Press 2019, 59, 729–739. [Google Scholar] [CrossRef] [Green Version]
  30. Sauvola, J.; Pietikainen, M. Adaptive Document Image Binarization. Pattern Recognit. 2000, 33, 225–236. [Google Scholar] [CrossRef] [Green Version]
  31. Petro, A.B.; Sbert, E.; Morel, J.-M. Multiscale Retinex. Image Process. Line 2014, 4, 71–88. [Google Scholar] [CrossRef]
  32. Ridler, T.W.; Calvard, S. Picture thresholding using an iterative selection method. IEEE Trans. Syst. Man Cybern. 1978, 8, 630–632. [Google Scholar]
  33. Xiao, J.; Wei, H. Scale-invariant contour segment context in object detection. Image Vis. Comput. 2014, 32, 1055–1066. [Google Scholar] [CrossRef]
  34. Kabsch, W. A solution for the best rotation to relate two sets of vectors. Acta Crystallogr. 1976, 32, 922–923. [Google Scholar] [CrossRef]
  35. Khawli, T.A.; Anwar, M.; Gan, D.; Islam, S. Integrating laser profile sensor to an industrial robotic arm for improving quality inspection in manufacturing processes. Proc. Inst. Mech. Eng. Part C J. Mech. Eng. Sci. 2020. [Google Scholar] [CrossRef]
  36. Wrobel, K.; Doroz, R. The New Method of Signature Recognition Based on Least Squares Contour Alignment. In Proceedings of the International Conference on Biometrics and Kansei Engineering, Cieszyn, Poland, 25–28 June 2009; pp. 80–83. [Google Scholar]
  37. Markovsky, I.; Mahmoodi, S. Least-Squares Contour Alignment. IEEE Signal Process. Lett. 2009, 16, 41–44. [Google Scholar] [CrossRef] [Green Version]
  38. Zhang, J.; Qiuand, Y.; Duan, X. Precise on-line non-_target pose measurement for cylindrical components based on laser scanning. Assem. Autom. 2019, 39, 596–606. [Google Scholar]
  39. Rothganger, F.; Lazebnik, S. 3D Object Modeling and Recognition Using Local Affine-Invariant Image Descriptors and Multi-View Spatial Constraints. Int. J. Comput. Vis. 2006, 66, 231–259. [Google Scholar] [CrossRef] [Green Version]
  40. Suzuki, S. Topological structural analysis of digitized binary images by border following. Comput. Vision, Graph. Image Process. 1985, 30, 32–46. [Google Scholar] [CrossRef]
  41. Biswas, S.; Aggarwal, G.; Chellappa, R. An Efficient and Robust Algorithm for Shape Indexing and Retrieval. IEEE Trans. Multimed. 2010, 12, 372–385. [Google Scholar] [CrossRef]
  42. Sharvit, D.; Chan, J.; Tek, H.; Kimia, B.B. Symmetry-based in-dexing of image databases. J. Vis. Commun. Image Represent. 1998, 9, 366–380. [Google Scholar] [CrossRef] [Green Version]
  43. Schmitt, J.; Bönig, J.; Borggräfe, T.; Beitinger, G.; Deuse, J. Predictive model-based quality inspection using Machine Learning and Edge Cloud Computing. Adv. Eng. Inform. 2020, 45, 101101. [Google Scholar] [CrossRef]
  44. Bradski, G. The OpenCV Library. Dr. Dobb J. Softw. Tools 2000, 25, 120–125. [Google Scholar]
Figure 1. The objects recognition and alignment tasks. From left to right: template, scan, the recognized object with transform, the aligned object (top view of 3D scenes).
Figure 1. The objects recognition and alignment tasks. From left to right: template, scan, the recognized object with transform, the aligned object (top view of 3D scenes).
Sensors 21 01529 g001
Figure 2. Our processing pipeline for object recognition and alignment.
Figure 2. Our processing pipeline for object recognition and alignment.
Sensors 21 01529 g002
Figure 3. Retinex filter. (a) The scanned depth map; (b) binarization of the scanned depth map by the IsoData threshold; (c) the output from the Retinex filter applied to the scanned depth map; (d) binarization of the Retinex filter output by the IsoData threshold.
Figure 3. Retinex filter. (a) The scanned depth map; (b) binarization of the scanned depth map by the IsoData threshold; (c) the output from the Retinex filter applied to the scanned depth map; (d) binarization of the Retinex filter output by the IsoData threshold.
Sensors 21 01529 g003
Figure 4. Shape descriptor based on the Triangle Area Representation (TAR). (a) Contour; (b) sampled contour (200 points) with an example of the considered triangle; (c) TAR descriptor (each line represents 200 normalized triangle areas; each area corresponds to point and its close neighbors) (d) illustrative triangles (indicating how far the neighbors are from the point).
Figure 4. Shape descriptor based on the Triangle Area Representation (TAR). (a) Contour; (b) sampled contour (200 points) with an example of the considered triangle; (c) TAR descriptor (each line represents 200 normalized triangle areas; each area corresponds to point and its close neighbors) (d) illustrative triangles (indicating how far the neighbors are from the point).
Sensors 21 01529 g004
Figure 5. An example of an object with symmetric shape and asymmetric aspects. (ad) Aligning by the outer shape, there are four possible alignments, but only one (c) is correct. (The template object is cyan, and the aligned one is red. Thus pure cyan represents a missing area and pure red an extra area.)
Figure 5. An example of an object with symmetric shape and asymmetric aspects. (ad) Aligning by the outer shape, there are four possible alignments, but only one (c) is correct. (The template object is cyan, and the aligned one is red. Thus pure cyan represents a missing area and pure red an extra area.)
Sensors 21 01529 g005
Figure 6. Extension of the TAR descriptor. (a) the sampled contour and holes with examples of triangle areas describing the inner object area. (b) the TAR descriptor with our extension (the bottom line). It is quite visible that the standard TAR values contain four same segments, whereas the extension two plus two. Thus alignment is uniquely determined.
Figure 6. Extension of the TAR descriptor. (a) the sampled contour and holes with examples of triangle areas describing the inner object area. (b) the TAR descriptor with our extension (the bottom line). It is quite visible that the standard TAR values contain four same segments, whereas the extension two plus two. Thus alignment is uniquely determined.
Sensors 21 01529 g006
Figure 7. Alignment of 3D contours. (a) Inputs to the alignment process; (b) the result provided by the Kabsch algorithm; (c) the output of our algorithm _targeted to contours alignment.
Figure 7. Alignment of 3D contours. (a) Inputs to the alignment process; (b) the result provided by the Kabsch algorithm; (c) the output of our algorithm _targeted to contours alignment.
Sensors 21 01529 g007
Figure 8. Results for a single input. (a) Contour selected for the template; (b) the input depth map; (c) the aligned depth map; (d) the recognized and aligned object.
Figure 8. Results for a single input. (a) Contour selected for the template; (b) the input depth map; (c) the aligned depth map; (d) the recognized and aligned object.
Sensors 21 01529 g008
Figure 9. Here, we present results for several objects and their scans. Each line offers five scans of the same item, from which the first one we select as the template (the first column). The gray color represents measured values while the green one the aligned depth map (we align the whole depth map for better comparison; the recognized object could also be separated, of course).
Figure 9. Here, we present results for several objects and their scans. Each line offers five scans of the same item, from which the first one we select as the template (the first column). The gray color represents measured values while the green one the aligned depth map (we align the whole depth map for better comparison; the recognized object could also be separated, of course).
Sensors 21 01529 g009
Table 1. The average shape distances for selected types of samples.
Table 1. The average shape distances for selected types of samples.
Sensors 21 01529 i001 Sensors 21 01529 i002 Sensors 21 01529 i003 Sensors 21 01529 i004
Sensors 21 01529 i00511.9521.4445.9885.41
Sensors 21 01529 i00621.246.1734.9699.99
Sensors 21 01529 i00745.8435.1514.16105.70
Sensors 21 01529 i00885.46100.10105.7223.51
Table 2. The average result precision and time consumption of the whole processing pipeline for selected types of samples
Table 2. The average result precision and time consumption of the whole processing pipeline for selected types of samples
Sensors 21 01529 i009 Sensors 21 01529 i010 Sensors 21 01529 i011 Sensors 21 01529 i012
precision0.35%0.12%0.49%0.42%
time
consumption
0.21s0.21s0.30s0.75s
Table 3. Comparison of comparable approaches, concerning the current state-of-the-art. We have qualitatively compared several methods based on the TAR and other shape descriptors. We have considered several features listed in the left column and evaluated their presence or quality of the individual approaches.
Table 3. Comparison of comparable approaches, concerning the current state-of-the-art. We have qualitatively compared several methods based on the TAR and other shape descriptors. We have considered several features listed in the left column and evaluated their presence or quality of the individual approaches.
Method:Hough
 [18]
HSD
 [26]
CSC
 [33]
SIFT
 [13]
TAR
 [24]
TAR
 [25]
Our
Approach
Number of objects:onemanymanyoneoneonemany
Types of objects:oneanyanyanyoneoneany
Overlapping objects:N/AnoyesN/AN/AN/Apartially
Symmetric shape objects
with asymmetric aspects
handled correctly:
N/AyesyesnoN/AN/Ayes
Complicated shapes
supported:
nonoyesyesyesyesyes
Phantom detections’
danger:
nonelowhighlownonenonenone
Alignment of
the recognized object:
yesnononoyes
rough
yes
rough
yes
precise
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Lucny, A.; Dillinger, V.; Kacurova, G.; Racev, M. Shape-Based Alignment of the Scanned Objects Concerning Their Asymmetric Aspects. Sensors 2021, 21, 1529. https://doi.org/10.3390/s21041529

AMA Style

Lucny A, Dillinger V, Kacurova G, Racev M. Shape-Based Alignment of the Scanned Objects Concerning Their Asymmetric Aspects. Sensors. 2021; 21(4):1529. https://doi.org/10.3390/s21041529

Chicago/Turabian Style

Lucny, Andrej, Viliam Dillinger, Gabriela Kacurova, and Marek Racev. 2021. "Shape-Based Alignment of the Scanned Objects Concerning Their Asymmetric Aspects" Sensors 21, no. 4: 1529. https://doi.org/10.3390/s21041529

APA Style

Lucny, A., Dillinger, V., Kacurova, G., & Racev, M. (2021). Shape-Based Alignment of the Scanned Objects Concerning Their Asymmetric Aspects. Sensors, 21(4), 1529. https://doi.org/10.3390/s21041529

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop
  NODES
admin 2
Association 2
Idea 6
idea 6
innovation 2
INTERN 37
Note 10
Project 2
twitter 1