The present invention relates generally to telecommunications service network technology, and more particularly to a system and method for clock synchronization in wireless backhaul networks using IEEE 1588 Precision Time Protocol.
Wireless backhaul networks are deployed to carry the traffic between a wireless access network and the core network. For example, a wireless backhaul network may comprise a plurality of hubs, each connected to the wired core network, via Ethernet. Each hub serves multiple remote backhaul modules (RBM), in a point-to-multipoint or point-to-point configuration, using a wireless channel. Each RBM is deployed close to an access network base station, such as a small cell base station, and connected to the base station via a cable. The hubs are deployed at the locations where wired, high capacity, access to the core network is available, e.g. at a fiber point-of-presence.
In this type of wireless backhaul network, time division duplexing (TDD) is used to separate the traffic transmitted from a hub to an RBM (downlink) and the traffic transmitted from an RBM to a hub (uplink). Thus, in multi-hub deployments, the hubs are required to be synchronized in time for efficient network operations. Thus each hub comprises a clock, and a method is required for synchronizing clocks of each hub.
The IEEE 1588 Precision Time Protocol (PTP) is a timing protocol used to synchronize distributed clocks throughout a network. For background information on IEEE 1588, and known methods for clock synchronization using PTP, reference is made to the following documents:
The IEEE 1588 standard provides for a hierarchical master-slave architecture for synchronization of distributed network clocks, in which a high-precision clock exchanges timing information with a clock of each node in the network. The high-precision clock is referred to as the master clock, while the clock of each node is referred to as a slave clock. Based on the timing information exchanged between the master clock and each slave clock, each slave clock is adjusted in an effort to achieve synchronization with the master clock.
Timing information between the master and slave clocks is exchanged through the following two main types of message exchange, as illustrated schematically in
Ideally, if both clocks are perfectly synchronized in frequency and phase, and if there is no queuing delay, then
However, due to frequency and phase offsets between the master and slave clocks, as well as queuing delay and time-stamping jitter, we have (Iantosca et al., ref. (3):
t2(i)−t1(i)=tmpd+αt1(i)+O+QF(i)+JF(i),
t4(i)−t3(i)=tmpd−αt4(i)−O+QR(i)+JR(i),
where
Thus, the objective of clock synchronization is to continuously adjust the frequency of the slave clock so that the frequency drift between the master and slave clock is approximately zero, i.e. α≈0, and the actual phase offset between the master and slave clock is approximately zero, i.e. O≈0.
An object of the present invention is to provide an improved or alternative method and system for network-wide clock synchronization in communications networks, and more particularly a method and system for clock synchronization in wireless backhaul networks comprising fixed or stationary nodes, including small cell non-line-of-sight (NLOS) backhaul networks.
Aspects of the present invention provide a system and method for clock synchronization in communications networks, including wireless backhaul networks, using IEEE 1588 PTP.
Thus, one aspect of the present invention provides a method for clock synchronization in a fixed wireless backhaul network using IEEE1588 Precision Time Protocol (PTP), the wireless backhaul network comprising a plurality of fixed nodes, each node comprising a hub or a Remote Backhaul Module (RBM), wherein each hub serves one or more Remote Backhaul Modules (RBMs), and wherein each hub comprises a slave clock, and each slave clock communicates with a master clock through a forward link (master-to-slave) and a reverse link (slave-to-master), the method comprising, for each slave clock, the steps of:
for a frame rate of Ft and a time window size W, during each time window W, obtaining a plurality of time-stamps, comprising t1 and t2, for the forward link and t3 and t4, for the reverse link, and storing said plurality of time stamps;
determining from said stored time stamps, for said time window W, an estimated frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)} for each of the forward and reverse links;
determining an estimation error Δ{circumflex over (α)} of the estimated drift frequency drift {circumflex over (α)} and an estimation error Δ{circumflex over (β)} of the estimated offset {circumflex over (β)} for each of the forward and reverse links;
determining which of the forward and reverse links is a least congested link; and
if the estimation errors Δ{circumflex over (α)} and Δ{circumflex over (β)} of the least congested link are less than or equal to a predefined maximum estimation error, adjusting the slave clock based on said estimated frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)} of the least congested link;
otherwise, changing the window size and repeating the preceding steps until the estimation errors Δ{circumflex over (α)} and Δ{circumflex over (β)} of the least congested link are less than or equal to a predefined maximum estimation error, or, declaring loss of synchronization.
If the estimation error errors Δ{circumflex over (α)} and Δ{circumflex over (β)} of the least congested link are greater than the maximum estimation error, the method may comprise incrementally increasing the time window size by a factor c, where c is greater than one, and repeating said steps until the estimation errors Δ{circumflex over (α)} and Δ{circumflex over (β)} of the least congested link are less than or equal to the predefined maximum estimation error.
If the estimation error errors Δ{circumflex over (α)} and Δ{circumflex over (β)} of the least congested link are less than or equal to the maximum estimation error, the method may comprise successively decreasing the time window size by an amount ΔW and repeating the preceding steps to find a minimum window size that provides estimation errors Δ{circumflex over (α)} and Δ{circumflex over (β)} of the least congested link that are less than or equal to the predefined maximum estimation error.
The least congested link of the forward and reverse links may be determined as the link that results in the least estimation error.
The method may further comprise, for each of the forward and reverse links, applying packet delay filtering to identify a plurality of lucky packets in said time window W, and applying linear regression on the plurality of lucky packets to obtain the estimated frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)}.
In an embodiment, determining estimated frequency drift frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)} for the forward and reverse links comprises:
for the forward link, determining intermediate drifts and offset values {tilde over (α)}, {tilde over (β)}, by solving the following optimization:
performing packet delay filtering (PDV) comprising applying packet filtering using the said intermediate values {tilde over (α)}, {tilde over (β)}, to identify lucky packets that satisfy the following condition:
LP={i:t2(i)−t1(i)≦{tilde over (α)}(t1(i)−t1(1))+{tilde over (β)}+6σJ}
nLP=|LP|, number of lucky packets
applying linear regression on the lucky packets to find the said estimated frequency drift frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)};
and correspondingly, for the reverse link, determining intermediate drifts and offset values {tilde over (α)}, {tilde over (β)}, by replacing t1 with t4 and t2−t1 with t4−t3) in the above optimization; and
defining the offset in forward link as O={circumflex over (β)}−tmpd and in the reverse link as O=−({circumflex over (β)}−tmpd).
The method may further comprise performing jitter filtering using linear regression comprising:
for the forward link,
let x, y, be two nLP×1 vectors, given by
x={t1(i)−t1(i):iεLP}, y={t2(i)−t1(i):iεLP}
and the estimated frequency drift and offset are given by
and, correspondingly, for the reverse link, replacing t1 with t4 and t2−t1 with t4−t3 in the above equations.
For a given Confidence level, CL %, the method may comprise estimating the estimation errors on {circumflex over (α)} and {circumflex over (β)}, denoted by Δ{circumflex over (α)} and Δ{circumflex over (β)}, respectively, such that αε[α−Δ{circumflex over (α)}, α+Δ{circumflex over (α)}] and βε[{circumflex over (β)}−Δ{circumflex over (β)}, {circumflex over (β)}+Δ{circumflex over (β)}];
For CL=99%, the following approximation may be used
tn
In an embodiment, determining the least congestion link of the forward and reverse links comprises selecting the link that results in the largest number of lucky packets.
The method may further comprise:
determining the maximum tolerable synchronization error, MaxSynchError, between the master clock and slave clock;
determining a target confidence level for synchronization; and
declaring loss of synchronization if
|{circumflex over (β)}−tmpd|+Δ{circumflex over (β)}≧MaxSynchError
where tmpd is the mean propagation delay.
The method may further comprise:
determining a target confidence level for synchronization, MaxSynchError; and computing a maximum holdover time as:
where {circumflex over (β)} is the estimated offset, Δ{circumflex over (β)} is the estimation error on {circumflex over (β)}, {circumflex over (α)} is the estimated drift, Δ{circumflex over (α)} is the estimation error on {circumflex over (α)}, and tmpd is the mean propagation delay.
Another aspect of the invention provides a system for clock synchronization using IEEE1588 precision time protocol (PTP) in a fixed wireless backhaul network comprising a plurality of nodes, said nodes comprising hubs and Remote Backhaul Modules (RBMs), wherein each hub serves one or more Remote Backhaul Modules (RBMs), each hub comprising a slave clock, and wherein each slave clock communicates with a master clock through a forward link (master-to-slave) and a reverse link (slave-to-master), and processor means comprising at least one processor and a computer readable storage medium, storing programming instructions for execution by said at least one processor, for implementing the claimed method.
In one embodiment, the system comprises a second order control loop, e.g. the processing unit comprises a proportional integral (PI) controller.
Yet another aspect of the invention provides a computer readable storage medium in a fixed wireless backhaul network comprising a plurality of nodes, said nodes comprising hubs and Remote Backhaul Modules (RBMs), wherein each hub serves one or more Remote Backhaul Modules (RBMs), each hub comprising a slave clock, and wherein each slave clock communicates with a master clock through a forward link (master-to-slave) and a reverse link (slave-to-master), the computer readable storage medium storing programming instructions for execution by said at least one processor, for implementing the claimed method.
Thus, the present invention provides a method, system and software for clock synchronization using IEEE1588 PTP in wireless backhaul networks.
The foregoing, and other objects, features, aspects and advantages of the present invention will become more apparent from the following detailed description, taken in conjunction with the accompanying drawings of preferred embodiments of the invention, which description is by way of example only.
A system and method for clock synchronization in a fixed wireless backhaul network will be described, by way of example, with reference to a NLOS wireless backhaul network 100 as illustrated schematically in
As an example only, the wireless backhaul network 100 shown in
In each sector 120, a Hub 102 serves its set or cluster of Remote Backhaul Modules (RBMs) 104 through wireless links (Hub-RBM radio links) 110, as shown schematically in
Time division duplexing (TDD) is used to separate the traffic transmitted from a hub to an RBM (downlink) and the traffic transmitted from an RBM to a hub (uplink). Thus, in multi-hub deployments, the hubs are required to be synchronized in time for efficient network operations. Each hub comprises a clock to enable synchronization of network operations and a method is required for synchronizing the clock of each hub, which will be referred to as a “slave clock”, with a high-precision clock or “master clock”.
The system and method for clock synchronization disclosed herein provides for synchronization of each slave clock, i.e. clocks located in each hub, with a high-precision master clock, based on the IEEE 1588 precision time protocol.
For application to the wireless backhaul network, the master clock may be a Grand Master high precision network clock outside the wireless backhaul network, i.e. an internet accessible master clock. It may alternatively be a high precision master clock provided in a centralized server/control node of the wireless backhaul network. The clock of the centralized server may act as a boundary clock, i.e. act as a master clock for the wireless backhaul network, which itself maintains close synchronization with a best master or grand master clock outside the wireless backhaul network.
Thus, in an embodiment, each hub comprises a slave clock and a processing unit for implementing synchronization of the hub with its designated master clock.
Considering synchronization of each hub with its respective master clock, and referring
However, due to the frequency and phase offset between the master and slave clocks, as well as, queuing delay and time-stamping jitter, we have (Iantosca et al. [3]):
t2(i)−t1(i)=tmpd+αt1(i)+O+QF(i)+JF(i),
t4(i)−t3(i)=tmpd−αt4(i)−O+QR(i)+JR(i),
where
To implement clock synchronization, in practice, it is required to obtain estimates of the frequency drift {circumflex over (α)} and offset {circumflex over (β)}.
The following notations are introduced:
For simplicity, in the following description, we refer in the following to the estimated frequency drift {circumflex over (α)}ε{{circumflex over (α)}12, {circumflex over (α)}34} and the estimated offset a {circumflex over (β)}ε{{circumflex over (α)}12, {circumflex over (β)}34}.
The overall methodology for synchronizing the slave clock and the master clock is to continuously adjust the frequency of the slave clock to make the frequency drift a α≈0 and the offset O≈0. This is done through the following three steps:
As an example, to illustrate the objective of the method,
In a method according to one embodiment of the present invention, estimating the frequency drift {circumflex over (α)}12 and offset {circumflex over (β)}12 in the forward link comprises:
{circumflex over (β)}12=
Accordingly, for the reverse link, the steps above can be used for estimating the frequency drift {circumflex over (α)}34 and offset {circumflex over (β)}34 in the reverse link by replacing t1 with t4 and (t2−t1) with (t4−t3).
Then, in forward link, the offset O={circumflex over (β)}−tmpd; and, in the reverse link, the offset O=−({circumflex over (β)}−tmpd).
Estimation Error
The method may further comprise computing the estimation error of the estimated frequency drift {circumflex over (α)}ε{{circumflex over (α)}12, {circumflex over (α)}34} and the estimated offset {circumflex over (β)}ε{{circumflex over (β)}12, {circumflex over (β)}34}, which are denoted by Δ{circumflex over (α)} and Δ{circumflex over (β)}, respectively, as follows:
define a Confidence Level, CL %, such that Pr(αε[{circumflex over (α)}−Δ{circumflex over (α)}+Δ{circumflex over (α)}])≦CL %, and Pr(βε[{circumflex over (β)}−Δ{circumflex over (β)}, {circumflex over (β)}+Δ{circumflex over (β)}])≦CL %;
let tn
for CL=99%, the following approximation can be used
then the estimation errors are given by:
Δ{circumflex over (α)}=Sαtn
Δ{circumflex over (β)}=Sβtn
Reducing Adverse Effects of Congestion with a Variable and Fixed Window Sizes
The method for clock synchronization may further comprise reducing the adverse effects of congestion, comprising checking the frequency estimation error of the forward link (using t1 and t2) and reverse link (using t3 and t4), and then adjusting the slave clock based on the link that has the least frequency estimation error. Higher estimation error is highly correlated with high congestion. If both links have a high estimation error, then the window size is increased. If the estimation error is less than a maximum estimation error, then the window size may be decreased.
The following parameters are defined:
The method then comprises performing steps defined by the following pseudocode:
In a variation of this embodiment, to provide a lower-complexity implementation, the method comprises performing steps defined by the following pseudocode:
In a method for clock synchronization according to another embodiment, the method provides a low-complexity implementation with a constant window size and method comprises performing steps defined by the following pseudocode:
Reducing Memory Storage
In yet another embodiment, the method for clock synchronization may further comprise reducing the memory storage required to estimate the frequency drift {circumflex over (α)} and offset {circumflex over (β)}, from complexity O(W) to complexity O(√{square root over (W)}).
A method of this embodiment comprises obtaining timestamps for every √{square root over (Np2keepW Ft)} packets, as illustrated schematically in
Then the frequency drift {circumflex over (α)}ε{{circumflex over (α)}12, {circumflex over (α)}34} and offset {circumflex over (β)}ε{{circumflex over (β)}12, {circumflex over (β)}34} are estimated for the stored √{square root over (Np2keepW Ft)} “lucky packets”. Note that in this case, the maximum number of packets that need to be stored is less than 2√{square root over (Np2keepW Ft)}.
Example: For W Ft=3840 packets, and Np2keep=4 packets, the maximum number of packets that need to be stored is <=248 packets, which is much less than 3840 packets.
Further reduction in storage requirements can be achieved by choosing a short observation window size (“small window”), of a fixed size, which is sufficient to obtain a desired minimum number of lucky packets, and running the above procedure recursively, for a plurality of said small windows. In general, it is possible to achieve storage of complexity O(n+1√{square root over (W)}), where n is the number of times the above procedure is run.
Holdover Time and Declaring Loss of Synchronization
The method may further comprise computing a maximum holdover time and declaring loss of synchronization:
let MaxSynchError denote the maximum tolerable synchronization error between the master clock and slave clock;
for a given Confidence level, CL %, obtain the estimation errors on {circumflex over (α)} and {circumflex over (β)}, which are denoted by Δ{circumflex over (α)} and Δ{circumflex over (β)}, as explained above;
and declaring loss of synchronization if
|{circumflex over (β)}−tmpd|+Δ{circumflex over (β)}≧MaxSynchError.
Thus, loss of synchronization is declared if this condition is met, e.g. if methods for clock synchronization comprising running one of the algorithms as described herein cannot achieve synchronization.
As described above, methods for clock synchronization based on the IEEE1588 PTP, according to embodiments of the present invention, comprise obtaining a plurality of timestamps, and using a combination of linear programming and linear regression to obtain the estimated the frequency drift {circumflex over (α)}ε{{circumflex over (α)}12, {circumflex over (α)}34} and estimated offset {circumflex over (β)}ε{{circumflex over (β)}12, {circumflex over (β)}34} for the forward and reverse links between a master clock and a slave clock, and estimation of the accuracy of {circumflex over (α)} and {circumflex over (β)}, i.e. Δ{circumflex over (α)} and Δ{circumflex over (β)}. The time window size W may be fixed or variable, and the time window size W is selected to achieve a desired accuracy of {circumflex over (α)} and {circumflex over (β)}.
An initial window size W is chosen based on simulations or experiment, since this value depends on actual hardware and equipment being used. Similarly, whether a fixed window size is used, or a variable window size is required, depends on whether or not synchronization can be achieved to meet system requirements, for example, to achieve synchronization within 500 ns, or with 100 ns or less, and with a desired level of confidence.
Beneficially, the method comprises performing packet delay filtering, defining a subset of a plurality of received packets referred to as lucky packets, and then performing linear regression for the lucky packets. Optionally, a recursive method using a small window size provides for reduced memory storage.
This approach is distinguished from known drift estimation schemes, such as those disclosed by Iantosca et al., ref. (3), and Anyaegbu et al., ref. (6), in the way packet delay filtering is performed in Step 3. In particular, in references (3) and (6), packet filtering is performed by dividing the time-stamps window into small windows, and selecting only one packet from each small window that corresponds to the packet with the minimum delay, i.e., selecting a minimum t2−t1, in each small window.
The method may further comprise estimating a maximum holdover time, and declaring loss of synchronization when synchronization is lost with the desired level of confidence. The maximum holdover time indicates the amount of time the system can maintain time synchronized in free-run without adjusting the clock.
System Architecture
IEEE1588 PTP provides a protocol for synchronization where an alternative shared timing source is not practical, or where other options for synchronization of distributed network devices having individual clocks to a GPS satellite or an NTP time server are not available. The methods of embodiments described herein are particularly applicable for wireless backhaul networks comprising a plurality of fixed (stationary) nodes comprising hubs and RBMs, such as illustrated schematically in
For application to such the wireless backhaul network, the master clock may be a Grand Master high precision network clock outside the wireless backhaul network, i.e. an internet accessible master clock. It may alternatively be a high precision master clock provided in the centralized server/control node of the wireless backhaul network. The clock of the centralized server may act as a boundary clock, i.e. act as a master clock for the wireless backhaul network, which itself maintains close synchronization with a best master or grand master clock outside the wireless backhaul network.
Thus, by way of example only, in a system according to an embodiment of the invention, comprising a wireless backhaul network having a network topology as illustrated schematically in
For synchronization of the hubs and their served RBMs, the slave clock of each hub may act as a master clock for its served RBMs. That is the network provides hierarchical clock synchronization for hubs and RBMs. Processing to perform clock synchronization according to embodiments of the invention may be performed by local or distributed processing means. For example, the processing means may comprises local processing units of each node, e.g. each hub and RBM, and/or a centralized control server, or the processing means may comprise distributed processing units, e.g. may be distributed amongst processors of some or all nodes.
Depending on network requirements, and processing capabilities of each hub and RBM, a fixed or variable window size W may be used, to obtain synchronization with a desired accuracy or level of confidence. If synchronization with a desired accuracy or level of confidence is not initially achieved, the window size is increased. An algorithm using a variable window size may be implemented. For example, if the level of confidence is not achieved, the window size is incrementally increased. On the other hand, if the level of confidence is exceeded, the window size is successively decreased to a minimum value that achieves a required level of confidence. Application of a smaller window size, which obtains a minimum number of lucky packets, reduces computational complexity and storage requirements. To reduce storage and computational requirements, recursive computation based on lucky packets for a plurality small window sizes reduces computational complexity. On the other hand, if the algorithm cannot obtain synchronization with the desired level of confidence, and e.g. a maximum holdover time is exceeded, or other requirements are not met, and a method using a selected algorithm and selected parameters such as fixed or variable window size W, cannot achieve synchronization, a loss of synchronization may be declared.
In one embodiment, each hub comprises a PI (proportional integral) controller to provide for implementation of clock synchronization using a second order control loop.
To synchronize hub-RBM communications, each RBM may also comprise a clock and processor for implementing clock synchronization. That is the clock of each hub acts as a master clock for its serving RBMs, and a clock of each RBM acts as a slave clock. Thus each RBM served by a hub may implement clock synchronization with the respective “master” clock of its hub.
In a method of another embodiment, clock synchronization of hubs and RBMs may be coordinated by a control node, such as a centralized control server which manages control functions of the wireless backhaul network.
Thus, it will be apparent that nodes of the network, e.g. individual hubs, RBMs or a centralized control server, may perform clock synchronization locally, or all or some of these nodes may act as a distributed system to provide clock synchronization across the wireless backhaul network.
Simulation Results
Packet Delay Variation Vs. Jitter
Thus methods and systems for clock synchronization using IEEE1588 PTP in a fixed wireless backhaul networks according to embodiments of the invention described herein provide for:
estimation of frequency drift and offset in the forward and reverse links using a combination of linear programming and linear regression, for a window size of W seconds;
estimation of the accuracy of the estimated frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)};
use of a variable window size to achieve a desired accuracy of estimated frequency drift {circumflex over (α)} and estimated offset {circumflex over (β)}.
The method optionally comprises estimating a maximum holdover time with a desired level of confidence, and declaring whenever the slave clock has lost synchronization with the desired level of confidence, and then performing clock synchronization.
Methods are also disclosed for reducing the adverse effects of congestion, including a low-complexity implementation with a variable window size and a low-complexity implementation with a constant window size.
Methods are also disclosed for reducing the memory storage required for estimating {circumflex over (α)} and {circumflex over (β)}.
Although embodiments of the invention have been described and illustrated in detail, it is to be clearly understood that the same is by way of illustration and example only and not to be taken by way of limitation, the scope of the present invention being limited only by the appended claims.
This application claims priority from U.S. Provisional patent application No. 62/055,045, filed Sep. 25, 2014, entitled “System and Method for Clock Synchronization in Wireless Backhaul Networks Based on IEEE 1588 Standard”, which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
8300749 | Hadzic | Oct 2012 | B2 |
8644348 | Zampetti | Feb 2014 | B2 |
8930484 | Ranasinghe | Jan 2015 | B2 |
8959381 | Aweya | Feb 2015 | B2 |
Entry |
---|
IEEE, “1588-2008—IEEE Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems,” Internet: http://standards.ieee.org/findstds/standard/1588-2008.html, Aug. 27, 2014. |
S.B. Moon, et al., “Estimation and removal of clock skew from network delay measurements”, in Proc. Eighteenth Annual Joint Conference of the IEEE Computer and Communications Societies (INFOCOM '99), Mar. 21-25, 1999. |
C. Iantosca et al., “Synchronizing IEEE 1588 clocks under the presence of significant stochastic network delays,” in Proc. 2005 Conference on IEEE 1588, CH Winterthur, Oct. 2005. |
ITU (International Telecommunications Union). “ITU-T G.8260 (2012), Definitions and terminology for synchronization in packet networks”, Internet https://www.itu.int/rec/T-REC-G.8260/en. |
Calnex Solutions Ltd., Application note: “Testing IEEE 1588v2 slave clocks CX5003”, Internet http://www.calnexsol.com/downloads/application-notes-and-whitepapers.html. |
M. Anyaegbu et al., “Dealing with Packet Delay Variation in IEEE 1588 Synchronization Using a Sample-Mode Filter,” IEEE Intelligent Transportation Systems Magazine, vol. 5, No. 4, pp. 20-27, 2013. |
Number | Date | Country | |
---|---|---|---|
20160095075 A1 | Mar 2016 | US |
Number | Date | Country | |
---|---|---|---|
62055045 | Sep 2014 | US |