Next Article in Journal
A Tuned Microwave Resonant System for Subcutaneous Imaging
Next Article in Special Issue
Homogeneous Sensor Fusion Optimization for Low-Cost Inertial Sensors
Previous Article in Journal
Effects of Upper Limb Robot-Assisted Rehabilitation Compared with Conventional Therapy in Patients with Stroke: Preliminary Results on a Daily Task Assessed Using Motion Analysis
Previous Article in Special Issue
Design and Fabrication of a Novel Wheel-Ring Triaxial Gyroscope
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Range-Extension Algorithms and Strategies for TDOA Ultra-Wideband Positioning System

1
Graduate Institute of Commutation Engineering, National Taiwan University, Taipei 106, Taiwan
2
School of Medicine, National Taiwan University, Taipei 106, Taiwan
*
Author to whom correspondence should be addressed.
Sensors 2023, 23(6), 3088; https://doi.org/10.3390/s23063088
Submission received: 29 January 2023 / Revised: 7 March 2023 / Accepted: 7 March 2023 / Published: 13 March 2023
(This article belongs to the Special Issue Advanced Inertial Sensors, Navigation, and Fusion)

Abstract

:
The Internet of Things (IoT) for smart industry requires the surveillance and management of people and objects. The ultra-wideband positioning system is an attractive solution for achieving centimeter-level accuracy in target location. While many studies have focused on improving the accuracy of the anchor coverage range, it is important to note that in practical applications, positioning areas are often limited and obstructed by furniture, shelves, pillars, or walls, which can restrict the placement of anchors. Furthermore, some positioning regions are located beyond anchor coverage, and a single group with few anchors may not be able to cover all rooms and aisles on a floor due to non-line-of-sight errors causing severe positioning errors. In this work, we propose a dynamic-reference anchor time difference of arrival (TDOA) compensation algorithm to enhance accuracy beyond anchor coverage by eliminating local minima of the TDOA loss function near anchors. We designed a multidimensional and multigroup TDOA positioning system with the aim of broadening the coverage of indoor positioning and accommodating complex indoor environments. By employing an address-filter technique and group-switching process, tags can seamlessly move between groups with a high positioning rate, low latency, and high accuracy. We deployed the system in a medical center to locate and manage researchers with infectious medical waste, demonstrating its usefulness for practical healthcare institutions. Our proposed positioning system can thus facilitate precise and wide-range indoor and outdoor wireless localization.

1. Introduction

1.1. Ultra-Wideband (UWB) Positioning

Positioning systems play a critical role in bridging the gap between people and the real world. The global positioning system (GPS) has matured in recent decades and has proven to be reliable technology for outdoor navigation, disaster rescue, and aircraft stabilization [1]. However, GPS is not suitable for indoor environments. Indoor positioning is vital for surveillance and management applications, including guiding customers in a shopping mall, navigating autonomous guided vehicles (AGVs) in factories or warehouses [2,3], developing collision avoidance systems for AGVs [4], and managing hazardous materials in a laboratory. A summary of recent indoor positioning scenarios and technologies is presented [5].
One commonly used technology for achieving high-accuracy positioning systems is ultra-wideband (UWB). Well known mobile phone providers, such as Apple [6], Google [7], and Samsung, develop their products with UWB chips [8]. For example, Apple’s AirTag, released in 2021, uses UWB technology to assist iPhone users in locating lost items [9]. UWB signals are impulses in the time domain with a bandwidth greater than 500 MHz. The precise impulse timestamps can help reduce the multipath effect. UWB chips provide channel impulse responses (CIRs), which can be used for non-line-of-sight (NLOS) identification or mitigation [10,11,12]. UWB can be combined with inertial measurement units (IMU) and GPS for indoor–outdoor roaming [13,14].

1.2. Time of Arrival (TOA)

Time of arrival (TOA) is the predominant positioning method employed in most UWB positioning systems. The distance between anchors and tags can be determined using two-way-ranging (TWR) [15]. Precise distance measurement enables accurate estimation of both 2D and 3D positions [16,17,18]. While the accuracy of TOA is generally superior among time-based methods, the latency of target positioning tends to increase with an increasing number of tags [19]. Consequently, the localization rate decreases rapidly, rendering TOA unsuitable for applications that involve a large number of targets.

1.3. Time Difference of Arrival (TDOA)

The time difference of arrival (TDOA) method estimates the differences in distance between a tag and any two anchors and then identifies the intersection of the hyperbolas to locate the tag. In an uplink TDOA system, anchors are synchronized using Ethernet or wireless signals [20]. Once the tag sends a data frame, the time differences can be computed. By using the ALOHA theorem [21], only approximately 18.6% of the timeframe can be utilized for collision-free communication because tags are not scheduled and transmitted randomly. Thus the tags can conserve power and reduce costs because random transmission does not require a powerful microcontroller.
In the downlink TDOA system, the slave anchors are triggered by a master anchor to transmit ranging messages in scheduled slots. The tags can determine the differences in the distance by comparing the receiving timestamps of the ranging messages [22]. The number of tags in the downlink system is unlimited, as the tags do not need to transmit messages. The positioning result is computed on the tag and must be uploaded to the server by out-of-band protocols such as Bluetooth low energy (BLE) or WiFi. Fortunately, the targets already equipped with such commercial wireless protocols can be quickly integrated with a downlink TDOA system. For example, AGVs are often monitored by WiFi, and mobile phones can access the Internet via 4G or 5G communication.

1.4. Extended Positioning Requirements

The positioning accuracy within the convex hull of the anchors surpasses that outside [23]. Ideally, anchors should be deployed to cover all desired positioning areas. However, realization and power concerns may prohibit anchor placement in the desired locations, resulting in parts of the positioning area being outside the convex hull. Additionally, in specific applications, such as drone positioning and landing systems [24,25,26], the target may be far from the anchors. The validation of out-of-range positioning is crucial for implementing and extending the usage of a positioning system.

1.5. Contributions

This study proposes a dynamic-reference anchor (DRA) algorithm to improve TDOA out-of-range positioning accuracy. The local minima in the loss function can be eliminated by selecting a proper reference anchor. In addition, a multidimensional and multigroup TDOA system is designed to expand the positioning coverage. The major contributions of this study are summarized as follows:
  • The DRA algorithm eliminates the local minima in the loss function, improving the out-of-range accuracy of TDOA.
  • Positioning coverage can be expanded by using multiple individual groups, and the group searching algorithm minimizes the roaming latency of tag.
  • The multidimensional groups are versatile in adapting to various complex indoor environments.
This paper is organized as follows. Section 2 provides a comparison of this proposed work with other related works. Section 3 analyzes the problem of the TDOA loss function outside the coverage of anchors. A simulation and experiment are conducted to prove the improvement of the DRA algorithm. Section 4 presents the multigroup and multidimensional TDOA positioning system, including group types, group bounding, group region, and the process of group switching. In Section 5, the proposed system is demonstrated with an application of medical waste management in a medical center. The bias problem of the 1D group is discussed in Section 6.1, and a solution is given in Section 6.2. Finally, Section 7 summarizes the conclusions and outlines future work.

2. Related Works

A system that uses additional anchors to expand the positioning range was proposed [27]. When the positioning target moves to unexpected areas, a new anchor can be deployed and located by the original anchors. However, the estimation errors of new anchors may accumulate when more additional anchors are used.
Ref. [28] used a positioning target with two tags, each connected to a different UWB network. The fusion of ranging results can improve accuracy if the quality of ranging is poor in one of the UWB networks. Although the concept of fusing multiple tags is interesting, it is not practical to equip a small device with a large number of tags in multiple networks.
The out-of-range positioning scenario in smart-following applications was discussed [29,30]. When the tag carried by a human master moves far away, the anchors on an AGV concentrate like a hotspot. The proposed anchor selection method uses the most asymmetric anchors to locate the tag to improve accuracy. However, in a rectangular room, the acceptable number of anchors is usually at most four, and only a few subsets can be selected.
Despite numerous studies on TDOA single-group wireless synchronization using stationary anchors [31,32,33], few practical solutions have been proposed to extend positioning coverage in severe NLOS scenarios. The plug-and-play localization system (PnPLoc) in which all anchors initiate TWR with nearby anchors was proposed [34], and additional anchors are not limited by the distance from a specified master anchor. However, the positioning rate decreases when there are many anchors in a large building. A multi-hop wireless synchronization algorithm was proposed in [35], where the synchronization signal from the master anchor propagates between anchors according to the synchronization quality treemap, reducing the synchronization error caused by NLOS in a building. However, line-of-sight (LOS) anchor pairs may not always be present between adjacent rooms, and a viable path may not be included in the treemap. The study in [36] proposed a grid-based positioning system in which TDOA anchors are placed as multiple grids and synchronized using wireless signals. Every anchor establishes a connection to the Internet to schedule time-division multiple access slots and transmit positioning data, while tags connect to the cell with the strongest received signal strength. Nevertheless, the proposed grid-like anchor deployment is unfeasible for complex indoor environments.

3. TDOA Positioning Algorithm

3.1. Existing Solutions

Consider a TDOA network with four anchors and a tag. The measured signal time difference between the i t h anchor and the j t h anchor, denoted as t i j , can be translated to the distance difference d i j by multiplying it by the light speed. Because d i j can be obtained from d i k d j k , any anchor can be chosen as the reference anchor. For example, if k = 1, the linear independent terms are d 21 , d 31 , and d 41 . The hyperbolas shaped by these terms would intersect at the tag position, as depicted in Figure 1.
In practical scenarios, hyperbolas often do not intersect at a single point due to measurement errors. Several TDOA algorithms have been proposed to find the optimal position, including the least square (LS) closed-form solution [37], Chan method [38], Taylor method [39], and gradient descent (GD) algorithm. However, LS and Chan methods may not provide sufficient accuracy due to approximation errors, while the Taylor method may converge to an incorrect position if the initial estimate is far from the true position. Although the GD algorithm provides better accuracy, it requires heavy computations. A hybrid method that combines Taylor and GD methods was proposed in [38] to improve accuracy, but it is still unsuitable for cost-effective IoT devices. A second-order term was added to the Taylor series [40] to improve the Taylor method, which achieved better convergence performance than the traditional Taylor method. In this study, we adopted the second-order Taylor (SOT) method as the base TDOA optimization algorithm. A brief derivation of SOT is presented below.
Suppose anchor k is selected as the reference anchor. The estimated position is p v = [ x v   y v ] with arbitrary initial values, and the number of anchors is N. The loss function at position p = [ x   y ] to the i t h anchor and the reference anchor can be defined as
f i p = x i x 2 + y i y 2 x k x 2 + y k y 2 = r i , k + ϵ i , k ,
where r i , k is the measured distance difference and ϵ i , k is the measurement error. By expanding (1) using Taylor series at p v and ignoring the high-order terms, (1) can be rewritten as
f i p v + a i δ r i , k ,   i = 1 , 2 , , N ,
where
a i = f i p x f i p y , δ = x v x y v y .
Then, the first-order Taylor step δ 1 can be solved as:
δ 1 = ( A 1 T A 1 ) 1 A 1 T D ,
where
A 1 = a 1 a 2 a N T , D = r 1 , 1 f 1 p v r 2 , 1 f 2 p v r N , 1 f N p v
Now consider the second-order term in the Taylor series; (2) becomes:
f i p v + a i δ + 1 2 δ T H i δ r i , 1 ,   i = 2 , 3 , , N ,
where
H i = 2 f i p x 2 2 f i p x y 2 f i p x y 2 f i p y 2 .
Because δ 1 is determined, which can be regarded as a constant, the second-order term δ T can be approximated by δ 1 T to translate (4) into a linear equation
f i p v + ( a i + 1 2 δ 1 T H i ) δ r i , 1 ,   i = 2 , 3 , , N .
The second-order step δ 2 can be solved by the least squares estimator
δ 2 = ( A 2 T A 2 ) 1 A 2 T D ,
where
A 2 = A 1 + 1 2 H 1 T δ 1 H 2 T δ 1 H N T δ 1 T .
Finally, p v can be updated by adding δ 2 at each iteration until δ 2 is smaller than the early stopping criterion, or the maximal iteration is reached. The derivation of SOT in detail can be found in [40].

3.2. Performance Analysis

A simulation of the SOT was performed for both the inside and outside areas. The simulation range was 3 m × 3 m, and the grid size was 0.1 m, where each point took 100 tests. In Figure 2, the red dots located at (−1.5, −1.5), (1.5, −1.5), (1.5, 1.5), and (−1.5, 1.5) are anchors 1 to 4, respectively. Anchor 1 was selected as the reference. Because there was no prior knowledge of the correct position, the estimated initial position was at the center of the anchors (0.0, 0.0) in each test. The simulated distance differences were noised by σ ~ N ( 0 ,   0.06 ) . The maximum epoch of the SOT was 30, and the early stop criterion was that the 2-norm of δ 2 was smaller than 0.001 m. The simulated root-mean-square error (RMSE) is shown in Figure 2. Values are represented by colors in the color bar. The areas with an RMSE greater than 0.7 m are colored as 0.7 m for better visualization.
In Figure 2, the performance is satisfactory inside the anchors, but outside the area, especially in the yellow cones outside anchors 1, 2, and 4, the performance is not optimal. Detailed analyses of the points (2.5, 2.5), (2.5, −2.5), (−2.5, 2.5), and (−2.5, −2.5) are presented in Figure 3, Figure 4, Figure 5 and Figure 6, respectively, to investigate why the yellow cone disappears outside anchor 3. In Figure 3a, the estimated positions are scattered around the actual position. However, as depicted in Figure 4a, the positions are split into two clusters. The cluster close to anchor 2 might be trapped in the local minimum of the loss map, as demonstrated in Figure 4b. The loss map was computed using noiseless data. However, due to noise in actual data, there could be changes in the loss map, causing estimations to converge towards local or global minima. A similar phenomenon is observed in Figure 5 and Figure 6.
In contrast, Figure 3b exhibits no local minima. The TDOA hyperbolas are responsible for the absence of local minima on the opposite side of the reference anchor. Although different choices of the reference anchor should yield the same global minima, the local minima positions depend on the reference anchor.

3.3. Dynamic Reference Anchor Algorithm

Because the opposite side of the reference anchor performs better than the others, the reference anchor can be changed according to the estimated position. This study proposes a dynamic reference anchor second-order Taylor (DRA-SOT) algorithm that updates the reference anchor in each iteration to eliminate the local minima that appear at the outside corner.
Suppose anchor 1 is the reference anchor during the measurement process. The original anchor position matrix A can be defined as
A = p 1 p 2 p N ,
where p n is the position of the n t h anchor, and the first term is the reference anchor. The measured distance difference vector R can be defined as
R = r 1 , 1 r 2 , 1 r N , 1 ,
where r i , j is defined as in Equation (1). Because there is no prior knowledge of the correct position, the reference anchor is arbitrary in the first iteration and the initial position p v can be set to the center of the anchors. In the second iteration, as p v moves toward the target, the index of the farthest anchor to p v can be found by
α = argmax i x i x v 2 + y i y v 2 .
Then, the translated data vector R can be generated by subtracting R by r α , 1 to make the arguments referenced to anchor α . For example, if N = 4 and α = 3 , then
R = r 1,1 r 3 , 1 r 2 , 1 r 3 , 1 0 r 4 , 1 r 3 , 1 .
The first term of R is the reference distance difference in the SOT method. Thus, R is updated by exchanging R [ 0 ] and R [ α ] :
R = 0 r 2 , 1 r 3 , 1 r 1 , 1 r 3 , 1 r 4 , 1 r 3 , 1 .
In addition, the anchor position matrix is translated by exchanging A [ 0 ] and A [ α ] :
A = p 3 p 2 p 0 p 4 .
Finally, A and R are passed to the SOT to update p v at each iteration. Note that the term r i , j for which i is equal to j is always 0. The procedure of DRA-SOT is shown in Algorithm 1.
Algorithm 1 Function DRA_SOT()
InputAnchor positions: ( x 1 , y 1 ), ( x 2 , y 2 ), …, ( x N , y N )
Distance differences: r 1 , 1 , r 2 , 1 , …, r N , 1
Early stop criterion: β
Maximal iteration: max_epoch
OutputEstimated position: ( x e s t , y e s t )
1Set (x, y) to the center of anchors
2Set n to 0
3whilen < max_epoch do
4 use (9) to find the reference anchor’s index α
5 Set R to [ r 1 , 1 , r 2 , 1 , …, r N , 1 ] - r α , 1
6 Set A to [[ x 1 , y 1 ], [ x 2 , y 2 ], …, [ x N , y N ]]
7 Exchange R [ 0 ] for R [ α ]
8 Exchange A [ 0 ] for A [ α ]
9 Use (3) to determine δ 1
10 Use (6) to determine δ 2
11 Set ( x , y ) to ( x + δ 2 x , y + δ 2 y )
12 Set n to n + 1
13 if norm( δ 2 ) < β  then
14  break
15 end if
16end while
17return (x, y)

3.4. Simulation

Figure 7a is a copy of Figure 2 and is placed here for comparison. The simulation results of DRA-SOT are plotted in Figure 7b. The ranges and conditions were the same as those described in Section 3.2. Compared with Figure 7a, the yellow cones outside the anchors disappear, while the other areas do not change much. The accuracy was significantly improved.
Another simulation of a rectangular case is performed, as shown in Figure 8. As in the square case, yellow cones occur at the outside corners in Figure 8a using the SOT method, except for anchor 3. The DRA-SOT method eliminates most areas of the yellow cones, as shown in Figure 8b.

3.5. Experiment

In the experiment, the anchors were placed at (±1.5 m, ±1.5 m), and the testing points are plotted in Figure 9 The tag collected 400 TDOA data points for each testing point and computed the position using the SOT and DRA-SOT methods. The reference anchor of SOT is anchor 1. The positioning results for the outside corner points A, C, E, and G are analyzed in Figure 10a. The red triangles denote the anchors. The brown and green dots represent the estimated positions using SOT and DRA-SOT, respectively. Most DRA-SOT dots are distributed around the correct position, whereas the SOT dots are often stuck at the local minima near the anchors, as in the simulation. The upper-right corner shows only green dots because the corner is already on the opposite side of the default reference anchor, and thus the estimations using SOT and DRA-SOT fully overlap.
Although the DRA-SOT method overcomes the local minima problem, the dots are scattered and spread. An effective strategy to stabilize these positions is to adopt an extended Kalman filter (EKF). The EKF is a predictor based on the Markov chain, which assumes that the positioning target obeys physical principles. It has been widely used in sensor fusion and data filtering [41,42,43]. The positions of the applied EKF are shown in Figure 10b. The SOT dots are still stuck at the local minima because filtering cannot eliminate bias. In contrast, the DRA-SOT dots become more centralized in the correct location.
The positioning RMSEs of all testing points are listed in Table 1. The outside corner points A, C, E, and G are significantly improved. The accuracy of internal points I, J, K, L, and M and the outside-edge points B, C, D, F, and H are almost the same for both methods. It was proven that the proposed DRA-SOT method with EKF could effectively improve the accuracy outside the range of anchors for a TDOA positioning system.

4. Multi-Group and Multi-Dimensional TDOA Network

4.1. Motivation

In this study, a TDOA positioning network consisting of a master anchor and a few slave anchors was called a group. The communication process can be found in [22]. The master anchor, usually anchor 1, schedules message slots for all slave anchors, as illustrated in Figure 11. When the slave anchors receive a control message from the master anchor, they transmit ranging messages at each scheduled time. In this network, the last anchor slot is followed by an empty slot to allow the tags to compute the positions. Assuming that the slot duration is t s l o t and the number of anchors is N, the period of a ranging round is
t r o u n d = ( N + 1 ) t s l o t
where an additional 1 represents an empty slot.
The clock difference between a tag and anchor may result in timestamp errors. This error can be compensated for by the time ratio of the transmitting period of an anchor and the receiving period at the tag in two ranging rounds [44]. Thus, a tag has to receive two ranging rounds to compute the corrected time difference.
Although the UWB positioning system performs well for a single group in an ideal environment, it is still unsuitable for indoor environments with rooms, walls, and pillars because of severe NLOS errors [33,45]. The impact of large metal objects is even more significant [46]. In addition, the anchors can be saved in an aisle-like environment when only a 1D position is required. A multigroup and multidimensional seamless TDOA network is proposed in this section to accommodate various indoor environments and positioning requirements.

4.2. Group Type

  • 2D Group
A group requires at least two hyperbolas to find the intersection point as the 2D position of the tag. Because the TDOA between two anchors shapes only one hyperbola, at least three anchors are required in a 2D group. The DRA-SOT algorithm introduced in Section 3.3 can be applied.
  • 1D Group
Most indoor environments include rooms and aisles. The 2D positioning system can be used in room-like spaces, but it may not be suitable for aisles. The geometric dilution of precision (GDOP) was developed to estimate the accuracy of satellite positioning and can be applied to a UWB positioning system [47]. According to [48], the GDOP of 2D anchors in a narrow aisle is excessively high, resulting in inaccurate estimations perpendicular to the aisle.
A 1D group aims to find the tag’s position between the two anchors, as depicted in Figure 12. The cost of manufacturing and deployment of anchors can be reduced when only the 1D positions of tags are required. Let us assume that the positions of anchors 1 and 2 are p 1 and p 2 , respectively. The tag is positioned at p v . The distances between the two anchors and the tag are d 1 and d 2 . Then, p v can be solved as follows:
p v = p 1 + d 1 n o r m ( p 1 , p 2 ) ( p 2 p 1 ) .

4.3. Group Bounding

Messages from different groups may be unaligned or conflicting. The package loss increases as the number of groups increases. Although the fully conflicting messages of different groups may not be received, the tag can minimize the processing time after receiving a message and restart receiving to capture more nearby messages.
The ranging message contains the group ID of each anchor. Because the tag needs only one group at a time to find its position, the idea is to select an appropriate group to bind and discard the messages from the other groups. When the tag receives a ranging message, it first checks whether the group ID is that expected. If so, it extracts the timestamp and calculates TDOA. Otherwise, it directly filters the message and restarts receiving it to save processing time.
An experiment was conducted to verify the benefits of group filtering. Two groups and one tag are placed in a laboratory, as shown in Figure 13. The tag was located at the center of each group. The slot duration was 15 ms in each group. The ranging period was 75 ms, calculated using (13). The ideal number of successful positions was 799 in 1 min, where the first round was excluded. The tag recorded the number of successful positions for 1 min when binding to group 1, to group 2, and without binding. Successful positioning can be considered only when the tag receives all messages in two consecutive rounds. The testing results are shown in Table 2 and Table 3. When no group was bound, the successful positioning percentages were 35.2% and 39.9% in each group, respectively, with an average of 37.55%. The percentages in the binding cases were 85.7% and 76.0%, respectively, with an average of 80.85%. This shows that binding to a group can significantly increase the probability of successful positioning in a multigroup network.

4.4. Group Region

4.4.1. Region Definition

The tag must know the effective positioning region of a group to bind or unbind it. The ideal positioning region is the convex hull of the anchors that covers all positioning areas. However, anchors may not be allowed to be placed at ideal locations. The positioning environment is not always a perfect rectangle that the four anchors can easily cover. The positioning region of a group should be defined according to the actual scenario. An example is shown in Figure 14. The red triangles represent anchors, and the gray area represents the desired positioning area. Blue points indicate the positioning regions.

4.4.2. Ray-Casting Algorithm

The positioning region is always a simple polygon in which any edge would never cut the other edge [49]. The ray-casting algorithm [50] can be used to check whether the Tag’s position is inside or outside a region. If a point lies inside a simple polygon, the ray cast from the point in any direction will intersect the polygon an odd number of times. An intersection implies an inside–outside state exchange. Because the ray will eventually be out of the polygon, the intersection number would always be odd if the point is inside. An example is shown in Figure 15. The ray cast from point A intersects with the edges an odd number of times, while that from point B intersects an even number of times.
Suppose the ray is cast toward the right. There is no intersection if a line segment is totally above or below the test point or lies on the left plane of the point. The critical cases are shown in Figure 16. In Figure 16a, the intersection should be considered only once when the ray starts from the point A passes through the common terminal of two line segments. Therefore, it should not be considered an intersection if the lower point of a segment touches the ray. In Figure 16b, the red-dashed circle represents a lower point that is ignored, and the horizontal line segment does not intersect with the ray cast from point B.
The ray-casting algorithm is implemented in Algorithm 2. Line 8 filters the cases when the segment is above p, the segment is horizontal, and the lower point of the segment touches the ray. Line 10 filters the case that the segment is on the left of the point. Lines 13–15 compute the slope of the segment and check if the intersection is on the left or right.
Algorithm 2 Function is PointWithinPolygon()
InputTest point p
Polygon points s 1 , s 2 , …, s N , s 1
OutputVerified result result
1Set count to 0
2Set i to 0
3while i < N  do
4Set ( p s t a r t ,   p e n d ) to (s[i], s[i + 1])
5Set i to i + 1
6 if p s t a r t [1] > = p[1] and p e n d [1] > = p[1] then
7continue
8else if p s t a r t [0] < p[0] and p e n d [0] < p[0] then
9  continue
10end if
11Set m to ( p e n d [0] − p s t a r t [0])/( p e n d [1] − p s t a r t [1])
12Set x c r o s s to p e n d [0] − ( p e n d [1] − p[1]) × m
13if x c r o s s < p[0] then
14continue
15 end if
16 Set count to count + 1
17end while
18if count is odd then
19 return True
20end if
21return False

4.5. Group Switching

4.5.1. Process

A diagram of the group switching is shown in Figure 17. The parameter GID represents the group ID of the received message. The currently bound group ID is denoted as BID. Note that the group IDs start from 1, where 0 is reserved for the no-bound case.
The BID value remains unchanged if the position is within the current group’s region. Otherwise, the tag searches for the group in the database whose region includes the position and assigns the BID to its ID, prioritizing 2D groups over 1D groups. If the tag does not fall within any group’s region, it assigns the BID to the nearest group’s ID based on the nearest boundary.
If the tag loses signal or cannot receive messages for a period, it should set the BID to 0 and release its association with the current group. To avoid message conflict when there is no existing group association, the tag may establish a binding with the first group it receives when the BID value is 0 until it obtains a position or times out.
The TDOA-based estimated position in 1D groups is always between the anchors and cannot determine whether the tag is inside or outside the region. However, 1D groups can be used in indoor aisle-style environments with concrete walls on both sides. If the tag leaves the aisle, the signal decays rapidly, and the tag can stop binding to the aisle group and be considered a positioning timeout case.

4.5.2. Latency

Let us assume a tag is positioned in group 1, but the position lies in group 2. After calculating the position, according to the rule of group switching, the tag changes the BID to 2. If the message from anchor 1 in group 2 is received immediately after changing the BID, then the latency would be two ranging periods, as shown in Figure 18. However, if anchor 1 of group 2 coincidentally transmits before the tag changes the BID, the message will be missed, as shown in Figure 19. The other messages in this ranging round will be invalid, and the latency will be three ranging periods.
Consider the probability of successful positioning discussed in Section 4.3. The expected latency of the best case can be corrected as
t s w _ b e s t = 2 t r o u n d R ,
where R , is the successful positioning percentage which is 80.85%. In the worst case, the first ranging period does not need to be corrected because missing invalid messages are unimportant. The expected latency of the worst case can be corrected as
t s w _ w o r s t = ( 1 + 2 R ) t r o u n d .
Finally, the expected latency is the average of (15) and (16):
t s w = ( 0.5 + 2 R ) t r o u n d .
The same deployment as that in Figure 13 is used to verify the inference. The range was 75 ms for each group. The expected latency was 223 ms, as calculated by (17). The positioning regions are depicted in Figure 20, which partially overlap to prevent unstable switching when the tag stays at the junction of regions. The group IDs and regions are programmed into the tag module in advance, and the switching process is implemented. The tag moves back and forth between Pos1 and Pos2 20 times and records the delay between two consecutive outputs with different group IDs. On average, the measured latency was 213 ms, close to the expected value.

5. Demonstration

The proposed multigroup positioning system was implemented and tested in a medical center. The positioning area contains a laboratory, aisle, and conference room, as shown in Figure 21. The conference room and laboratory were covered by 2D groups: group 1 and group 2. The aisle was covered by group 3, a 1D group. The red triangles represent the anchors, and the colored areas represent the region of each group. Note that the region of group 3 was unused and defined for better visualization.
Due to concerns about the existing medical equipment and the transportation of infectious biological material, the anchors in the laboratory can only be deployed in fixed positions that do not provide full coverage. The tags used in this experiment are shown in Figure 22. Tags 1 and 3 are inside the badges worn by the two researchers. Tag 2 was held by another researcher who was carrying biomedical waste bins for the management of infectious substances.
The 2D groups used DRA-SOT to compute the TDOA position, whereas the 1D group used the algorithm introduced in Section 4.2. The EKF was applied to smooth the trace when tags moved between the groups. The positioning frequency of each group was set to 8 Hz. The positioning timeout was 0.5 s.
The real trace of tag 1 is shown in Figure 23a. It started in the conference room, moved to the left of the aisle, and finally stopped at the center of the aisle. Figure 23b shows the estimated trace of tag 1 as green dots. The largest dot corresponds to the last position. The total number of collected data was 929, and the positioning RMSE was 28.23 cm. When tag 1 stepped into the aisle, the positions were continuous and accurate because the next desired group could be found using the 2D position estimated in group 1.
Figure 24a shows the real trace of tag 2. The start and end points are represented by S and E, respectively. It started at the middle of the aisle and moved to the laboratory, which has three rows separated by two working desks with iron shelves. The researcher entered the rows in sequence and came out, standing in front of the door. Figure 24b shows the estimated trace of tag 2 as yellow dots. The total number of collected data was 638, and the positioning RMSE was 45.05 cm. When tag 2 entered the laboratory from the aisle, the measured latency was 1.871 s. Tag 2 could only unbind group 3 in the aisle after a timeout to receive group 2 in the laboratory. The estimated positions in the laboratory rows are scattered because of the severe NLOS errors caused by shelves and the human body.
Figure 25a shows the real trace of tag 3. It started at the laboratory door, entered the rows, and passed through the aisle to the conference room. Figure 25b shows the estimated trace as blue dots. The total number of collected data was 737, and the positioning RMSE was 22.85 cm. The trace of tag 3 is similar to that of tag 2, but its RMSE is lower than that of tag 2. It performed better in the second row in the laboratory and conference room and thus lowered the RMSE. The cumulative distribution function (CDF) of the positioning errors for the three tags are depicted in Figure 26.

6. Discussion

6.1. Bias in 1D Group

The traces from the laboratory to the aisle exhibit a right-bias in Figure 24b and Figure 25b, while the trace from the conference room to the aisle does not show any bias. This can be attributed to the TDOA loss function, as depicted in Figure 27. The ideal estimation for the tag’s position is its projection onto the 1D line marked by the blue cross. However, due to the curvature of the TDOA hyperbola, the intersection with the 1D line occurs at the red cross, resulting in a bias towards the right. This bias increases as the tag move further away from the 1D line. This issue can be resolved by adding another anchor, which is discussed in the next section.

6.2. Extended Anchor for 1D Group

Applying an additional anchor to a 1D group can provide the semi-2D position of a tag, as illustrated in Figure 28. The hyperbolas generated by the three anchors, denoted by C 12 , C 13 , and C 23 , intersect at the tag’s position. Because the semi-2D position can be found, the bias discussed in Section 6.1 does not exist.
Furthermore, the region of a 1D group can be defined by its width, as illustrated in Figure 29. By using semi-2D positioning, the tag can determine if it is within the group’s region. If not, the tag can set the BID to 0 and search for other groups instead of waiting for a timeout. This approach can reduce the latency of leaving a 1D group.

7. Conclusions

This research paper presents novel algorithms and strategies for expanding the positioning range of a TDOA system. The proposed reference-anchor selection algorithm DRA-SOT enhances accuracy when a tag is positioned beyond the convex hull of the anchors. By selecting an appropriate reference anchor, the local minima of the TDOA loss function around the anchors can be eliminated. Theoretically, the DRA algorithm can be applied to any TDOA optimization method to prevent it from being trapped in local minima. Experimental results demonstrate that the combination of DRA-SOT and EKF can significantly enhance performance in the outside corners of the positioning region compared to methods that do not utilize DRA.
The proposed multigroup system allows for an extended range of coverage in positioning areas where a single group is insufficient. By employing an address-filtering process, the system resolves message conflict problems between groups and improves the likelihood of successful positioning. To facilitate low-latency multigroup roaming, the system incorporates a group-switching process that has been implemented and verified. Furthermore, the proposed 1D group can be utilized in aisle-like environments, thereby reducing anchor deployment costs. A demonstration of the system’s effectiveness was conducted at a medical center, wherein multidimensional groups were employed to cover a laboratory, conference room, and long aisle. The tags were deployed on infectious medical waste and medical researchers to enable security and safety management, and the system accurately located the trajectories crossing the groups. An analysis of the positioning bias and switching latency in the 1D group was conducted, and a potential solution was introduced. This topic is still being investigated and will be further discussed in the future. The proposed multigroup system represents a significant breakthrough in extending the range of coverage for positioning systems. Through the use of an address-filtering process and group-switching mechanism, the system can operate efficiently in complex indoor environments. Furthermore, the application of the 1D group in aisle-like environments offers a cost-effective solution for anchor deployment. The system’s performance was validated through a demonstration that involved tracking tags on infectious medical waste and medical researchers, with the results demonstrating the accurate location of trajectories crossing the groups. The range-extension algorithm and strategies proposed in this paper can also be applied in smart factories, intelligent warehouses, unmanned drone patrols, and other related applications.

Author Contributions

Conceptualization, S.-P.H.; data curation, C.-B.C.; methodology, T.-Z.W., W.-T.T. and C.-Y.L.; Visualization, S.-P.H.; supervision, S.-G.M. and W.-H.S.; writing—original draft, S.-P.H. and Y.-M.M. All authors have read and agreed to the published version of the manuscript.

Funding

Ministry of Science and Technology, Taiwan, R.O.C.

Data Availability Statement

The data are not publicly available due to privacy concerns.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Um, I.; Park, S.; Kim, H.T.; Kim, H. Configuring RTK-GPS Architecture for System Redundancy in Multi-Drone Operations. IEEE Access 2020, 8, 76228–76242. [Google Scholar] [CrossRef]
  2. Rohrig, C.; Spieker, S. Tracking of Transport Vehicles for Warehouse Management Using a Wireless Sensor Network. In Proceedings of the 2008 IEEE/RSJ International Conference on Intelligent Robots and Systems, Nice, France, 22–26 September 2008; pp. 3260–3265. [Google Scholar]
  3. Crețu-Sîrcu, A.L.; Schiøler, H.; Cederholm, J.P.; Sîrcu, I.; Schjørring, A.; Larrad, I.R.; Berardinelli, G.; Madsen, O. Evaluation and Comparison of Ultrasonic and UWB Technology for Indoor Localization in an Industrial Environment. Sensors 2022, 22, 2927. [Google Scholar] [CrossRef] [PubMed]
  4. Zamora-Cadenas, L.; Velez, I.; Sierra-Garcia, J.E. UWB-Based Safety System for Autonomous Guided Vehicles Without Hardware on the Infrastructure. IEEE Access 2021, 9, 96430–96443. [Google Scholar] [CrossRef]
  5. Yang, T.; Cabani, A.; Chafouk, H. A Survey of Recent Indoor Localization Scenarios and Methodologies. Sensors 2021, 21, 8086. [Google Scholar] [CrossRef]
  6. Coppens, D.; Shahid, A.; Lemey, S.; Van Herbruggen, B.; Marshall, C.; De Poorter, E. An Overview of UWB Standards and Organizations (IEEE 802.15.4, FiRa, Apple): Interoperability Aspects and Future Research Directions. IEEE Access 2022, 10, 70219–70241. [Google Scholar] [CrossRef]
  7. Google Wants to Give Third-Party Apps Access to the Pixel 6 Pro’s Ultra-Wideband Chip. Available online: https://www.androidpolice.com/google-wants-to-give-third-party-apps-access-to-the-pixel-6-pros-ultra-wideband-chip (accessed on 30 November 2022).
  8. What Is Ultra-Wideband (UWB) Technology on Samsung Phones? How Is It Helpful? Available online: https://www.smartprix.com/bytes/phones-with-uwb-ultrawideband-connectivity (accessed on 30 November 2022).
  9. An Ultra-Wide-Band Device Comparison. Available online: https://www.techinsights.com/zh-tw/node/37564 (accessed on 30 November 2022).
  10. Barral, V.; Escudero, C.J.; García-Naya, J.A.; Maneiro-Catoira, R. NLOS Identification and Mitigation Using Low-Cost UWB Devices. Sensors 2019, 19, 3464. [Google Scholar] [CrossRef] [Green Version]
  11. Liu, A.; Lin, S.; Wang, J.; Kong, X. A Succinct Method for Non-Line-of-Sight Mitigation for Ultra-Wideband Indoor Positioning System. Sensors 2022, 22, 8247. [Google Scholar] [CrossRef]
  12. Chen, Y.-Y.; Huang, S.-P.; Wu, T.-W.; Tsai, W.-T.; Liou, C.-Y.; Mao, S.-G. UWB System for Indoor Positioning and Tracking with Arbitrary Target Orientation, Optimal Anchor Location, and Adaptive NLOS Mitigation. IEEE Trans. Veh. Technol. 2020, 69, 9304–9314. [Google Scholar] [CrossRef]
  13. Jiang, W.; Cao, Z.; Cai, B.; Li, B.; Wang, J. Indoor and Outdoor Seamless Positioning Method Using UWB Enhanced Multi-Sensor Tightly-Coupled Integration. IEEE Trans. Veh. Technol. 2021, 70, 10633–10645. [Google Scholar] [CrossRef]
  14. Huang, Z.; Jin, S.; Su, K.; Tang, X. Multi-GNSS Precise Point Positioning with UWB Tightly Coupled Integration. Sensors 2022, 22, 2232. [Google Scholar] [CrossRef]
  15. Implementation of Two-Way Ranging with the DW1000 (Application Note APS013). Available online: https://www.qorvo.com/products/d/da008448 (accessed on 30 November 2022).
  16. Sesyuk, A.; Ioannou, S.; Raspopoulos, M. A Survey of 3D Indoor Localization Systems and Technologies. Sensors 2022, 22, 9380. [Google Scholar] [CrossRef] [PubMed]
  17. Zhou, N.; Si, M.; Li, D.; Seow, C.K.; Mi, J. An Indoor UWB 3D Positioning Method for Coplanar Base Stations. Sensors 2022, 22, 9634. [Google Scholar] [CrossRef] [PubMed]
  18. Gerwen, J.V.-V.; Geebelen, K.; Wan, J.; Joseph, W.; Hoebeke, J.; De Poorter, E. Indoor Drone Positioning: Accuracy and Cost Trade-Off for Sensor Fusion. IEEE Trans. Veh. Technol. 2022, 71, 961–974. [Google Scholar] [CrossRef]
  19. Choi, B.; La, K.; Lee, S. UWB TDOA/TOA Measurement System with Wireless Time Synchronization and Simultaneous Tag and Anchor Positioning. In Proceedings of the 2018 IEEE International Conference on Computational Intelligence and Virtual Environments for Measurement Systems and Applications (CIVEMSA), Ottawa, ON, Canada, 12–13 June 2018; pp. 1–6. [Google Scholar]
  20. Zhang, F.; Yang, L.; Liu, Y.; Ding, Y.; Yang, S.-H.; Li, H. Design and Implementation of Real-Time Localization System (RTLS) Based on UWB and TDoA Algorithm. Sensors 2022, 22, 4353. [Google Scholar] [CrossRef]
  21. Ridolfi, M.; Van de Velde, S.; Steendam, H.; De Poorter, E. Analysis of the Scalability of UWB Indoor Localization Solutions for High User Densities. Sensors 2018, 18, 1875. [Google Scholar] [CrossRef] [Green Version]
  22. Huang, S.-P.; Neo, J.-F.; Chen, Y.-Y.; Chen, C.-B.; Wu, T.-W.; Peng, Z.-A.; Tsai, W.-T.; Liou, C.-Y.; Sheng, W.-H.; Mao, S.-G. Ultra-Wideband Positioning Sensor with Application to an Autonomous Ultraviolet-C Disinfection Vehicle. Sensors 2021, 21, 5223. [Google Scholar] [CrossRef]
  23. Grasso, P.; Innocente, M.S.; Tai, J.J.; Haas, O.; Dizqah, A.M. Analysis and Accuracy Improvement of UWB-TDoA-Based Indoor Positioning System. Sensors 2022, 22, 9136. [Google Scholar] [CrossRef]
  24. Lee, S.; Yoo, S.; Lee, J.Y.; Park, S.; Kim, H. Drone Positioning System Using UWB Sensing and Out-of-Band Control. IEEE Sens. J. 2022, 22, 5329–5343. [Google Scholar] [CrossRef]
  25. Ochoa-de-Eribe-Landaberea, A.; Zamora-Cadenas, L.; Peñagaricano-Muñoa, O.; Velez, I. UWB and IMU-Based UAV’s Assistance System for Autonomous Landing on a Platform. Sensors 2022, 22, 2347. [Google Scholar] [CrossRef]
  26. Dong, X.; Gao, Y.; Guo, J.; Zuo, S.; Xiang, J.; Li, D.; Tu, Z. An Integrated UWB-IMU-Vision Framework for Autonomous Approaching and Landing of UAVs. Aerospace 2022, 9, 797. [Google Scholar] [CrossRef]
  27. Xu, X.; Liu, X.; Zhao, B.; Yang, B. An Extensible Positioning System for Locating Mobile Robots in Unfamiliar Environments. Sensors 2019, 19, 4025. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  28. Jiménez, A.R.; Seco, F. Improving the Accuracy of Decawave’s UWB MDEK1001 Location System by Gaining Access to Multiple Ranges. Sensors 2021, 21, 1787. [Google Scholar] [CrossRef] [PubMed]
  29. Martalò, M.; Perri, S.; Verdano, G.; De Mola, F.; Monica, F.; Ferrari, G. Improved UWB TDoA-Based Positioning Using a Single Hotspot for Industrial IoT Applications. IEEE Trans. Ind. Inform. 2022, 18, 3915–3925. [Google Scholar] [CrossRef]
  30. Martaló, M.; Ferrari, G.; Perri, S.; Verdano, G.; Mola, F.D.; Monica, F. UWB TDoA-Based Positioning Using a Single Hotspot with Multiple Anchors. In Proceedings of the 2019 4th International Conference on Computing, Communications and Security (ICCCS), Rome, Italy, 10–12 October 2019; pp. 1–7. [Google Scholar]
  31. Großiwindhager, B.; Stocker, M.; Rath, M.; Boano, C.A.; Römer, K. SnapLoc: An Ultra-Fast UWB-Based Indoor Localization System for an Unlimited Number of Tags. In Proceedings of the 2019 18th ACM/IEEE International Conference on Information Processing in Sensor Networks (IPSN), Montreal, QC, Canada, 15–18 April 2019; pp. 61–72. [Google Scholar]
  32. Navrátil, V.; Krška, J.; Vejražka, F. Concurrent Bidirectional TDoA Positioning in UWB Network with Free-Running Clocks. IEEE Trans. Aerosp. Electron. Syst. 2022, 58, 4434–4450. [Google Scholar] [CrossRef]
  33. Hamer, M.; D’Andrea, R. Self-Calibrating Ultra-Wideband Network Supporting Multi-Robot Localization. IEEE Access 2018, 6, 22292–22304. [Google Scholar] [CrossRef]
  34. Chen, H.; Dhekne, A. PnPLoc: UWB Based Plug & Play Indoor Localization. In Proceedings of the 2022 IEEE 12th International Conference on Indoor Positioning and Indoor Navigation (IPIN), Beijing, China, 5–8 September 2022; pp. 1–8. [Google Scholar]
  35. Friedrich, J.; Tiemann, J.; Wietfeld, C. Accurate Multi-Zone UWB TDOA Localization Utilizing Cascaded Wireless Clock Synchronization. In Proceedings of the 2021 International Conference on Indoor Positioning and Indoor Navigation (IPIN), Lloret de Mar, Spain, 29 November–2 December 2021; pp. 1–8. [Google Scholar]
  36. Xue, Y.; Su, W.; Yang, D.; Wang, H.; Zhang, W. RMLNet—A Reliable Wireless Network for a Multiarea TDOA-Based Localization System. Sensors 2019, 19, 4374. [Google Scholar] [CrossRef] [Green Version]
  37. Yang, K.; An, J.; Bu, X.; Sun, G. Constrained Total Least-Squares Location Algorithm Using Time-Difference-of-Arrival Measurements. IEEE Trans. Veh. Technol. 2010, 59, 1558–1562. [Google Scholar] [CrossRef]
  38. Li, A.; Luan, F. An Improved Localization Algorithm Based on CHAN with High Positioning Accuracy in NLOS-WGN Environment. In Proceedings of the 2018 10th International Conference on Intelligent Human-Machine Systems and Cybernetics (IHMSC), Hangzhou, China, 25–26 August 2018; Volume 1, pp. 332–335. [Google Scholar]
  39. Cheng, Y.; Zhou, T. UWB Indoor Positioning Algorithm Based on TDOA Technology. In Proceedings of the 2019 10th International Conference on Information Technology in Medicine and Education (ITME), Qingdao, China, 23–25 August 2019; pp. 777–782. [Google Scholar]
  40. Yu, K.; Guo, Y.J.; Oppermann, I. Modified Taylor series expansion based positioning algorithms. In Proceedings of the VTC Spring 2008–IEEE Vehicular Technology Conference, Marina Bay, Singapore, 11–14 May 2008. [Google Scholar]
  41. Gagnon, E.; Vachon, A.; Beaudoin, Y. Data Fusion Architectures for Orthogonal Redundant Inertial Measurement Units. Sensors 2018, 18, 1910. [Google Scholar] [CrossRef] [Green Version]
  42. Hellmers, H.; Kasmi, Z.; Norrdine, A.; Eichhorn, A. Accurate 3D Positioning for a Mobile Platform in Non-Line-of-Sight Scenarios Based on IMU/Magnetometer Sensor Fusion. Sensors 2018, 18, 126. [Google Scholar] [CrossRef] [Green Version]
  43. Li, X.; Wang, Y.; Khoshelham, K. A Robust and Adaptive Complementary Kalman Filter Based on Mahalanobis Distance for Ultra Wideband/Inertial Measurement Unit Fusion Positioning. Sensors 2018, 18, 3435. [Google Scholar] [CrossRef] [Green Version]
  44. Zhao, K.; Zhao, T.; Zheng, Z.; Yu, C.; Ma, D.; Rabie, K.; Kharel, R. Optimization of Time Synchronization and Algorithms with TDOA Based Indoor Positioning Technique for Internet of Things. Sensors 2020, 20, 6513. [Google Scholar] [CrossRef]
  45. Tong, H.; Xin, N.; Su, X.; Chen, T.; Wu, J. A Robust PDR/UWB Integrated Indoor Localization Approach for Pedestrians in Harsh Environments. Sensors 2020, 20, 193. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  46. Gao, D.; Li, A.; Fu, J. Analysis of Positioning Performance of UWB System in Metal NLOS Environment. In Proceedings of the 2018 Chinese Automation Congress (CAC), Xi’an, China, 30 November–2 December 2018; pp. 600–604. [Google Scholar]
  47. Zhou, R.; Sun, H.; Li, H.; Luo, W. TDOA and Track Optimization of UAV Swarm Based on D-Optimality. J. Syst. Eng. Electron. 2020, 31, 1140–1151. [Google Scholar] [CrossRef]
  48. Guo, Y.; Li, W.; Yang, G.; Jiao, Z.; Yan, J. Combining Dilution of Precision and Kalman Filtering for UWB Positioning in a Narrow Space. Remote Sens. 2022, 14, 5409. [Google Scholar] [CrossRef]
  49. Toth, C.D.; O’Rourke, J.; Goodman, J.E. (Eds.) Handbook of Discrete and Computational Geometry, 3rd ed.; Chapman and Hall/CRC: Boca Raton, FL, USA, 2017. [Google Scholar]
  50. Shimrat, M. Algorithm 112: Position of point relative to polygon. Commun. ACM 1962, 5, 434. [Google Scholar] [CrossRef]
Figure 1. Time difference of arrival (TDOA) hyperbolas. The blue square denotes the tag.
Figure 1. Time difference of arrival (TDOA) hyperbolas. The blue square denotes the tag.
Sensors 23 03088 g001
Figure 2. Simulated root-mean-square error (RMSE) of the second-order Taylor (SOT) method.
Figure 2. Simulated root-mean-square error (RMSE) of the second-order Taylor (SOT) method.
Sensors 23 03088 g002
Figure 3. (a) Estimated positions and (b) loss map of point (2.5, 2.5).
Figure 3. (a) Estimated positions and (b) loss map of point (2.5, 2.5).
Sensors 23 03088 g003
Figure 4. (a) Estimated positions and (b) loss map of point (2.5, −2.5).
Figure 4. (a) Estimated positions and (b) loss map of point (2.5, −2.5).
Sensors 23 03088 g004
Figure 5. (a) Estimated positions and (b) loss map of point (−2.5, 2.5).
Figure 5. (a) Estimated positions and (b) loss map of point (−2.5, 2.5).
Sensors 23 03088 g005
Figure 6. (a) Estimated positions and (b) loss map of point (−2.5, −2.5).
Figure 6. (a) Estimated positions and (b) loss map of point (−2.5, −2.5).
Sensors 23 03088 g006
Figure 7. Simulated RMSE for square deployment using (a) SOT, (b) dynamic reference anchor SOT (DRA-SOT).
Figure 7. Simulated RMSE for square deployment using (a) SOT, (b) dynamic reference anchor SOT (DRA-SOT).
Sensors 23 03088 g007
Figure 8. Simulated RMSE for rectangle deployment using (a) SOT, (b) DRA-SOT.
Figure 8. Simulated RMSE for rectangle deployment using (a) SOT, (b) DRA-SOT.
Sensors 23 03088 g008
Figure 9. Testing points.
Figure 9. Testing points.
Sensors 23 03088 g009
Figure 10. Experiment results (a) without extended Kalman filter (EKF), (b) with EKF.
Figure 10. Experiment results (a) without extended Kalman filter (EKF), (b) with EKF.
Sensors 23 03088 g010
Figure 11. Slots of ranging rounds.
Figure 11. Slots of ranging rounds.
Sensors 23 03088 g011
Figure 12. The 1D group structure.
Figure 12. The 1D group structure.
Sensors 23 03088 g012
Figure 13. Group filtering deployment.
Figure 13. Group filtering deployment.
Sensors 23 03088 g013
Figure 14. Region of a 2D group.
Figure 14. Region of a 2D group.
Sensors 23 03088 g014
Figure 15. The ray-casting algorithm.
Figure 15. The ray-casting algorithm.
Sensors 23 03088 g015
Figure 16. The (a)common terminal case (b) line segment case of polygon intersection.
Figure 16. The (a)common terminal case (b) line segment case of polygon intersection.
Sensors 23 03088 g016
Figure 17. Process of switching group.
Figure 17. Process of switching group.
Sensors 23 03088 g017
Figure 18. The best case for the switching group.
Figure 18. The best case for the switching group.
Sensors 23 03088 g018
Figure 19. The worst case for the switching group.
Figure 19. The worst case for the switching group.
Sensors 23 03088 g019
Figure 20. Latency test deployment.
Figure 20. Latency test deployment.
Sensors 23 03088 g020
Figure 21. Deployment of groups.
Figure 21. Deployment of groups.
Sensors 23 03088 g021
Figure 22. The tags in the experiment.
Figure 22. The tags in the experiment.
Sensors 23 03088 g022
Figure 23. (a) Real trace and (b) estimated trace of tag 1.
Figure 23. (a) Real trace and (b) estimated trace of tag 1.
Sensors 23 03088 g023aSensors 23 03088 g023b
Figure 24. (a) Real trace and (b) estimated trace of tag 2.
Figure 24. (a) Real trace and (b) estimated trace of tag 2.
Sensors 23 03088 g024aSensors 23 03088 g024b
Figure 25. (a) Real trace and (b) estimated trace of tag 3.
Figure 25. (a) Real trace and (b) estimated trace of tag 3.
Sensors 23 03088 g025aSensors 23 03088 g025b
Figure 26. Positioning error CDF of (a) tag 1, (b) tag 2, (c) tag 3.
Figure 26. Positioning error CDF of (a) tag 1, (b) tag 2, (c) tag 3.
Sensors 23 03088 g026
Figure 27. Cause of 1D bias.
Figure 27. Cause of 1D bias.
Sensors 23 03088 g027
Figure 28. Hyperbolas in a 3-anchor 1D group.
Figure 28. Hyperbolas in a 3-anchor 1D group.
Sensors 23 03088 g028
Figure 29. Region of a 3-anchor 1D group.
Figure 29. Region of a 3-anchor 1D group.
Sensors 23 03088 g029
Table 1. The experimental positioning RMSEs.
Table 1. The experimental positioning RMSEs.
PositionTypeSOT + EKFDRA-SOT + EKFImproved
AOutside0.8690.3760.493
BOutside0.2670.272−0.005
COutside0.3650.3650.000
DOutside0.2430.1730.070
EOutside0.5700.2310.339
FOutside0.1700.1270.043
GOutside0.5540.1340.420
HOutside0.0770.0660.011
IInside0.0480.0480.000
JInside0.0530.0530.000
KInside0.0600.0360.024
LInside0.0380.0370.001
MInside0.0900.092−0.002
Unit: meter.
Table 2. The number of successful positioning in three testing cases.
Table 2. The number of successful positioning in three testing cases.
Group IDBinding
Group 1
Binding
Group 2
No Bound
16850281
20607319
Table 3. The percentage of successful positioning in three testing cases.
Table 3. The percentage of successful positioning in three testing cases.
Group IDBinding
Group 1
Binding
Group 2
No Bound
185.7%035.2%
2076.0%39.9%
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Share and Cite

MDPI and ACS Style

Huang, S.-P.; Chen, C.-B.; Wei, T.-Z.; Tsai, W.-T.; Liou, C.-Y.; Mao, Y.-M.; Sheng, W.-H.; Mao, S.-G. Range-Extension Algorithms and Strategies for TDOA Ultra-Wideband Positioning System. Sensors 2023, 23, 3088. https://doi.org/10.3390/s23063088

AMA Style

Huang S-P, Chen C-B, Wei T-Z, Tsai W-T, Liou C-Y, Mao Y-M, Sheng W-H, Mao S-G. Range-Extension Algorithms and Strategies for TDOA Ultra-Wideband Positioning System. Sensors. 2023; 23(6):3088. https://doi.org/10.3390/s23063088

Chicago/Turabian Style

Huang, Shih-Ping, Chien-Bang Chen, Tan-Zhi Wei, Wei-Ting Tsai, Chong-Yi Liou, Yuan-Mou Mao, Wang-Huei Sheng, and Shau-Gang Mao. 2023. "Range-Extension Algorithms and Strategies for TDOA Ultra-Wideband Positioning System" Sensors 23, no. 6: 3088. https://doi.org/10.3390/s23063088

APA Style

Huang, S. -P., Chen, C. -B., Wei, T. -Z., Tsai, W. -T., Liou, C. -Y., Mao, Y. -M., Sheng, W. -H., & Mao, S. -G. (2023). Range-Extension Algorithms and Strategies for TDOA Ultra-Wideband Positioning System. Sensors, 23(6), 3088. https://doi.org/10.3390/s23063088

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