This invention relates to packet selection techniques that can be used in conjunction with a clock recovery mechanism to mitigate the effects of packet delay variation on timing messages exchanged over a packet network, particularly when seeking to synchronize the time of a clock in a slave device to that of a master clock. The packet selection techniques can assist in reducing the noise in the recovered clock signal at the slave device, allowing recovery to a higher quality. Embodiments of the invention provide techniques based on extracting timing packets that create a constant interval between the arrival of selected packets at the slave device and on extracting timing packets which are closest to making the interval between arrival of the selected packets equal to the interval between the departure of the packets.
|
1. A method of selecting packets transmitted from a first device to a second device over a packet network, the method including the steps of:
sending, from the first device to the second device, packets;
recording the time of receipt of said packets according to a clock in the second device;
repeatedly, for each of a plurality of groups of said packets:
determining an optimal inter-arrival time between successive packets at the second device;
calculating, for each packet in said group, the inter-arrival time between the packet and the preceding packet;
selecting the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time;
sending, from the first device to the second device, timestamps which are the time of sending said packets from the first device according to a clock in the first device;
determining, for each packet in said group, the inter-departure time between the packet and the preceding packet from the first device,
wherein an optimal inter-arrival time is determined for each packet as the inter-departure time between said packet and the preceding packet; and
using the selected packets in the synchronization of the clock in the second device to the clock in the first device.
4. A first networked device connected to a second networked device over a packet network, wherein the first networked device has a clock, a memory, and a processor coupled to the memory, the processor configured to:
receive packets from the second device;
record the time of receipt of said packets according to said clock;
repeatedly, for each of a plurality of groups of said packets:
determine an optimal inter-arrival time between successive packets at the first device;
calculate, for each packet in said group, the inter-arrival time between the packet and the preceding packet;
select the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time;
receive, from the second networked device, timestamps which are the time of sending said packets from the second device according to a clock in the second device; and
determine, for each packet in said group, the inter-departure time between the packet and the preceding packet from the second device,
wherein an optimal inter-arrival time is determined for each packet as the inter-departure time between said packet and the preceding packet; and
synchronize the clock in the first networked device to the clock in the second networked device using the selected timing messages.
7. A networked system, the system including:
a first networked device;
a second networked device having a clock, a memory, and a processor coupled to the memory; and
a packet network connecting the first and second devices, wherein the processor of the second networked device is configured to:
receive packets from the first device;
record the time of receipt of said packets according to said clock;
repeatedly, for each of a plurality of groups of said packets:
determine an optimal inter-arrival time between successive packets at the second device;
calculate, for each packet in said group, the inter-arrival time between the packet and the preceding packet;
select the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time;
receive, from the first device, timestamps which are the time of sending said packets from the first device according to a clock in the first device; and
determine, for each packet in said group, the inter-departure time between the packet and the preceding packet from the first device,
wherein an optimal inter-arrival time is determined for each packet as the inter-departure time between said packet and the preceding packet; and
synchronize the clock in the second device to the clock in the first device using the selected timing messages.
2. A method according to
3. A method according to
5. A networked device according to
6. A networked device according to
8. A networked system according to
9. A networked system according to
|
The present invention relates to packet selection techniques that can be used in conjunction with a clock recovery mechanism. It is particularly, but not exclusively, concerned with packet selection in the context of time and/or frequency synchronization over packet networks using, for example, the IEEE 1588 Precision Time Protocol (PTP).
IEEE 1588 PTP is defined in the IEEE 1588-2002 (Version 1) and 1588-2008 (Version 2) standards. IEEE 1588 is designed as an improvement to current methods of synchronization within a distributed network of devices. It is designed for systems requiring very high accuracies beyond those attainable using Network Time Protocol (NTP). The IEEE 1588, unlike NTP, is able to deliver timing accuracy well under a microsecond. It is also designed for applications that cannot bear the cost of a GPS receiver at each node, or for which the GPS signals are inaccessible as is the case with a majority of picocell and femtocell base stations.
IEEE 1588 is now the industry accepted packet-based protocol used for transferring timing information to clocks of distributed systems to allow them to be synchronized to a master with accuracies in the nanoseconds level. PTP is a message based protocol that can be implemented across a range of packet based networking technologies, not limited to Ethernet. The underlying principle is a master/slave concept based on regular exchange of synchronization messages. IEEE 1588 synchronizes all slave clocks by allowing to them adjust their frequency/time to highest quality clock (the GrandMaster clock).
Packet delay variation (“PDV”) is the main factor affecting the accuracy and stability of slave clocks when using packet timing protocols such as IEEE 1588 PTP. The PDV is introduced by packet network devices such as switches and routers that receive and queue packets between a sender and receiver. PDV is a direct contributor to the noise in the recovered clock. Unless mitigated, the higher the PDV, the higher the clock noise and subsequently the poorer the clock quality. If the clock noise exceeds application defined thresholds the clocks are unusable for the end system. The term clock noise here refers to all impairments to the timing information recovered at the slave including jitter, wander and other imperfections in the recovered clocks.
For instance, for time synchronization, the delay variations experienced by packets traversing the packet network translate into noise in the slave's perception of the time at the master. Variable delay causes a varying estimate of the time offset between slave and master clocks. For these reasons, synchronization mechanisms used for end-to-end timing transfer require PDV mitigation mechanisms in order to accurately reconstruct the master clock. The performance of the slave's clock recovery process is highly affected by how efficient the packet selection algorithm (i.e., PDV mitigation mechanism) used by the slave is at reducing the level of PDV seen by the slave.
Overview of IEEE 1588v2 PTP
The GrandMaster (GM) is the timing reference in a domain and transmits synchronization information to the clocks residing in its domain. In IEEE 1588v2 PTP messages are categorized into event and general messages. All IEEE 1588 PTP messages have a common header. Event messages are timed messages with generated accurate timestamp at both transmission and receipt of each message. Event messages have to be accurately timestamped since the accuracy in transmission and receipt timestamps directly affects clock distribution accuracy. A timestamp event is generated at the time of transmission and reception of any event message. The set of event messages consists of Sync, DelayReq, Pdelay_Req and Pdelay_Resp. The set of general messages consists of Announce, Follow_Up, Delay_Resp, Pdelay_Resp_Follow_Up, Management and Signaling.
IEEE 1588 PTP allows for two different types of timestamping methods, either one-step or two step. One-step clocks update time information within event messages (Sync and Delay_Req) on-the-fly, while two-step clocks convey the precise timestamps of packets in general messages (Follow_Up and Delay_Resp).
The Sync, Delay_Req, Follow_Up and Delay_Resp messages are used to generate and communicate the timing information needed to synchronize ordinary and boundary clocks using the delay request-response mechanism. A Sync message is transmitted by a master to its slaves and either contains the exact time of its transmission or is followed by a Follow_Up message containing this time. In a two step ordinary or boundary clock, the Follow_Up message communicates the value of the departure timestamp for a particular Sync message. A Delay_Req message is a request for the receiving node to return the time at which the Delay_Req message was received, using a Delay_Resp message.
A basic pattern of synchronization message exchanges for the one step and two-step clocks are illustrated in
At the end of this PTP message exchange, the slave 3 possesses all four timestamps {T1, T2, T3, T4}. These timestamps may be used to compute the offset of the slave's clock 5 with respect to the master clock 4 and the mean propagation time of messages between the two clocks. The computation of offset and propagation time assumes that the master-to-slave and slave-to-master propagation times are equal, i.e. a symmetrical communication path.
Like NTP, PTP requires an accurate measurement of the communication path delay between the time server (master) 1 and the client (slave) 3. PTP measures the exact message transmit and receive times and uses these times to calculate the communication path delay and clock offset. This delay measurement principle determines the path delay between devices on the network and the local clocks 4 are adjusted for this delay using the series of messages sent between master 1 and slaves 3 (as shown in
In addition to the fixed propagation (or physical communication medium) delay, any packet traveling through the packet network 2 might experience additional variable delays as it travels from sender to receiver due to traffic loading and scheduling in the network components (switches, routers). That is, instead of the constant travel time (caused by the physical distance) the packets show variable delay according to the network topology and current load.
A packet selection mechanism can be used in this end-to-end timing transfer scenario to reduce the effects of PDV on the recovered clock at the slave.
Packet Pre-Processing (Selection) for Clock Recovery
One way of delivering frequency/time from a master 1 to a slave 3 is to send IEEE 1588 PTP messages in an end-to-end manner as illustrated in
The recovered clock from the PTP timing signal at the slave 3 contains clock noise (contributed largely by PDV) that needs to be removed. A filtering process is typically used at the slave 3 to filter out the clock noise, thus generating a “smooth” clock output. This process is also often referred to as clock recovery. The clock recovery process in packet networks often involves two major components, a packet pre-processing module 10 and a phase-locked loop (PLL) or servo control mechanism 20 as illustrated in
These two mechanisms are used together to attenuate the clock noise introduced by the packet network to levels commensurate with the clock output requirements of the application. Both the packet selection block 10 and the low pass filter function of the PLL 20 work to remove noise from the packet timing signal to faithfully re-create the timing source. The ‘cleaned’ timing signal can then be used to discipline the local oscillator.
The two modules in
The PLL 20 has low-pass and high-pass characteristics with a common corner frequency. The bandwidth of the loop comprises the frequencies below the corner frequency. The following observations can be made about the filtering characteristics of the PLL:
The filtering behavior of the PLL 20 is equivalent to an “averaging” process where the time-constant represents the duration over which the averaging is performed. The PLL cut-off frequency and time-constant have a reciprocal relationship and are equivalent descriptors of the low-pass filtering action.
From the above discussion we see that in the absence of packet pre-processing, the low-pass filtering action of the PLL 20 is solely responsible for attenuating the entire PDV so that the recovered clock will be compliant with the clock requirements of the application. To achieve this, the low-pass filter of the PLL may have to be designed to have a very small cutoff frequency (meaning PLL has very small bandwidth). The drawback, however, in doing this is that the very low-pass PLL leads to a high-pass characteristic where the loop allows more local oscillator noise to pass through to the clock output. This means that the reduction of the bandwidth of the PLL should not be done arbitrarily, but should take into account the quality of the local oscillator. It is for these reasons that applications with more stringent requirements demand higher quality oscillators. A high quality oscillator is stable and generates less noise that passes through to the clock output. At this point, it should be appreciated that packet pre-processing significantly helps to reduce the clock noise power at the PLL input and thereby can be used to alleviate the requirement of a very high quality (and expensive) oscillator. Efficient pre-processing can allow for the use of less expensive oscillators.
In the general case without packet pre-processing, synchronization performance is affected to a great extent by network design and its characteristics: traffic loading, PDV, route changes, etc. The greater the PDV, the more difficult it is to maintain synchronization between master and slave. Even with packet pre-processing (selection), the quality of the recovered clock at the slave will depend on how well the packet selection algorithm screens out the PDV in the arriving PTP messages.
Basics of Packet Selection for Clock Recovery
The basic schema of the packet selection process is illustrated in
The most important piece or block in
Commonly Used Packet Selection Techniques
As explained above, in order to reduce the clock noise produced as a result of the PDV, the slave 3 implements a packet selection (pre-processing) technique that allows it to use only a subset of the received timing packets, that is, the timing packets that are least affected by PDV. The idea is to select a specific subset of the PDV affected samples, having similar delay properties, among the entire population of PDV samples and pass these to the slave clock recovery mechanism.
Let {xk} denote samples of a hypothetical packet time-error signal x(t). In packet timing scenarios the time error signal is typically based on measurements of the transit delay of (timing) packets over the network between the master 1 and slave 3. Let xn represent the delay of the nth timing packet through the network and let
Xk={xn}, kL≦n≦(k+1)L−1, (1)
be a vector representing the kth window of size L on which the packet selection operation is performed. Typically, in PTP the packet transit delay xn (the elements of vector Xk) of Sync messages are calculated by taking the difference between the departure timestamp T1(n) and the arrival timestamp T2(n):
xn=T2(n)−T1(n). (2)
Similarly, the transit delays of Delay_Req messages can be calculated using T4(n) and T3(n) as shown in
yk=g(Xk) (3)
Some examples of the simplest packet selection methods are described below. Other more advanced methods such as percentile, band and cluster are described in the literature (e.g., [1][2][[3][4]).
This method involves selecting the minimum delay within a window of delay samples. This selection function can be represented as follows:
g(Xk)=min{xk}, kL≦n≦(k+1)L−1 (4)
The minimum packet selection and percentile packet selection both focus on packet data at the floor. The notion of “floor delay” is equivalent to the notion of minimum possible transit delay of packets over a network.
This method involves selecting the maximum delay within a window of delay samples. This selection function can be represented as follows:
g(Xk)=max{xn}, kL≦n≦(k+1)L−1 (5)
This method involves selecting the mean delay of delay samples within a window. This selection function can be represented as follows:
In the above packet selection methods, the representative delay value obtained in a window (min, max, or mean value) are used in some form in the packet recovery mechanism at the slave.
Timing Precision Evaluation in Packet Networks
In order for a slave to optimally recover time and frequency, packet selection is essential. The performance of a packet selection (pre-processing) method can be assessed by applying a stability quantification metric over the selected group of samples. This is illustrated schematically in
As illustrated in
As indicated above, a number of packet selection algorithms can be applied to Xk. These time windows can be either overlapping or non-overlapping. In the minimum packet selection method (“min”), effective for sequences with a good population of minimum delay packets, the minimum in the window is selected. The percentile method takes a number of packets at or near the minimum, and averages them together to produce an X′k sequence sample. The band selection method first sorts all the data in a time window from minimum to maximum, then selects a cluster of points at some chosen range, say between the 20th and 30th percentiles, and averages them together to produce a sample in the X′k sequence.
We explain briefly here why TDEV has become an important stability qualification metric for timing studies. This has become a common metric that is used to analyze the performance of a packet-based synchronization mechanism such as IEEE 1588 PTP. Variances are commonly used to characterize the fluctuation of a frequency source, but standard variance is not suitable for frequency stability measurement [2, 3]. The Allan Variance/Deviation, Modified Alan Variance/Deviation (MVAR/MDEV) and Time Deviation (TDEV) are the most common metrics used to quantify frequency stability. Specifically, TDEV is related to the MDEV and is used globally in the telecommunications industry to measure the time stability of frequency sources. However, it has been noted in the ITU-T standard [4] there can be some discrepancies between the information provided by a given PDV metrics and the real performance achieved by a slave clock. The regular TDEV metrics is defined as follows:
where τ=n·τ0τ=n·τ0, τ0 is a packet arrival frequency, n is length of a selection window, {•} is an ensemble average. In the use of the regular TDEV with packet pre-processed, the packet selection is done prior to the stability calculation, where the TDEV is applied to the resulting sequence (which is performed in the traditional way). This is how we compare the performance of all the proposed techniques set out.
Note the above approach for computing TDEV using packet pre-processing is different from the integrated packet selection approach, where the packet selection is integrated into the metric calculation [2][4]. Generally integrated packet selection approach involves replacing a full population averaging calculation with a selection process that may or may not itself include averaging. Integrated packet selection replaces the averaging with a selection process such as the min, percentile, and band. As a result a new self-contained metric is formed such as minTDEV, percentileTDEV, bandTDEV, minMAFE, percentileMAFE, or bandMAFE. An example of this is to replace the averaging operation present within the TDEV calculation with a minimum selection process forming a new calculation, i.e. minTDEV(x) [2][4].
Review of Some Packet Selection Studies
So far, there has not been extensive research done in the area of packet selection mechanisms for the clock recovery beyond the basics described in the ITU-T standards (min, percentile, band, cluster). The most relevant research in this area was carried out by Hadić and Morgan [1]. They proposed an adaptive technique based on very simple criteria (minimum, maximum and mean) for the packet selection. These simple criteria were derived from studies carried out by measuring and analyzing the PDV characteristics of different network topologies and traffic loading.
In order to analyze the performance of the techniques proposed in the present invention the PDV distributions obtained in [1] will be used, which are deemed realistic enough for synchronization studies. The PDV distribution in [1] has been accurately modelled to obtain the histograms in
Based on the measured PDV distributions three different types of packet selection techniques were derived in [1]. We will refer to the PDV distributions for the 20%, 40% and 80% load scenarios as the minPDV, maxPDV and meanPDV distributions, respectively. The studies in [1] determined that for the 20%, 40% and 80% network load scenarios, the minimum, maximum and mean packet selection criteria were optimal, respectively. We therefore call this technique here the Min/Max/Mean Algorithm (MMMA).
The idea behind the selection of these particular criteria in [1] is simple. By applying the criteria on the different distribution in
From the above discussion we can see that the MMMA is directly tied to the PDV distribution (
An object of the present invention is to provide a packet selection technique that significantly reduces the PDV when the selected packets are compared to the complete set of packets received by a device.
An further object of the present invention is to provide a packet selection technique that works well regardless of the network topology, traffic loading, and PDV distribution. In particular it is desirable that any technique should work well regardless of the type of PDV distribution it is exposed to (for example, whether left-skewed, centered or right-skewed as shown in
It is a further object of the present invention to provide a packet selection technique which can be used in a clock synchronization technique to improve the overall quality of the synchronized clock in the slave device, more particularly by reducing the clock variation introduced by PDV.
An exemplary embodiment of the invention provides a method of selecting packets transmitted from a first device to a second device over a packet network, the method including the steps of: sending, from the first device to the second device, packets; recording the time of receipt of said packets according to a clock in the second device; repeatedly, for each of a plurality of groups of said packets: determining an optimal inter-arrival time between successive packets at the second device; calculating, for each packet in said group, the inter-arrival time between the packet and the preceding packet; selecting the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time.
A further exemplary embodiment of the invention provides a first networked device connected to a second networked device over a packet network, wherein the first networked device has a clock and is arranged to: receive packets from the second device; record the time of receipt of said packets according to said clock; repeatedly, for each of a plurality of groups of said packets: determine an optimal inter-arrival time between successive packets at the first device; calculate, for each packet in said group, the inter-arrival time between the packet and the preceding packet; select the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time.
A further exemplary embodiment of the invention provides a networked system, the system including: a first networked device; a second networked device having a clock; and a packet network connecting the first and second devices, wherein the second networked device is arranged to: receive packets from the first device; record the time of receipt of said packets according to said clock; repeatedly, for each of a plurality of groups of said packets: determine an optimal inter-arrival time between successive packets at the second device; calculate, for each packet in said group, the inter-arrival time between the packet and the preceding packet; select the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time.
Embodiments of the invention will now be described by way of example with reference to the accompanying drawings in which:
At their broadest, methods of the present invention provide a packet selection method which selects the packets which have characteristics closest to an optimal delay characteristic.
A first aspect of the present invention provides a method of selecting packets transmitted from a first device to a second device over a packet network, the method including the steps of: sending, from the first device to the second device, packets; recording the time of receipt of said packets according to a clock in the second device; repeatedly, for each of a plurality of groups of said packets: determining an optimal inter-arrival time between successive packets at the second device; calculating, for each packet in said group, the inter-arrival time between the packet and the preceding packet; selecting the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time.
The method of this aspect can provide a packet (or message) selection technique that selects packets with low packet delay variation (PDV) or noise induced by their passage across the network. The selected packets can then be used for applications which require low noise characteristics, such as clock synchronization.
Preferably the groups of packets are all the packets arriving within a selected time window prior to the current time (i.e. the time at which the selection process runs).
In certain embodiments, the optimal inter-arrival time is determined as the mean of the inter-arrival times of the packets in the group.
In alternative embodiments, the optimal inter-arrival time is determined as the mean of the inter-arrival times of all packets received since a predetermined time equal to or prior to the receipt of the first packet in the group.
In these embodiments, a “running mean” of the inter-arrival times may be maintained or estimated by the method to avoid the need to calculate the mean afresh on the arrival of each packet or once all the packets in the group have been received. This results in a computationally efficient calculation of the optimal inter-arrival time. One particular example of such a running mean uses an exponentially weighted moving average of the inter-arrival times.
In other embodiments, the optimal inter-arrival time is determined as the median of the inter-arrival times of the packets in the group. In alternative embodiments, the optimal inter-arrival time is determined as the median of the inter-arrival times of all packets received since a predetermined time equal to or prior to the receipt of the first packet in the group.
Using a median rather than a mean may have advantages since it will be less influenced by outlier data points (values that are particularly small or large and therefore not typical of the data set as a whole) and skewed data. However, since the calculation of a median requires the storing of the inter-arrival time data for all packets which are to be used in the calculation of the median, the amount of such data is preferably limited to a selected “window” of packets prior to the time of the calculation.
The choice of the length of window may be varied depending on the situation. A longer window requires greater storage of previous values, and a more complex sorting operation to calculate the median. A shorter window runs the risk of not being statistically representative of the overall data set and being skewed by low frequency noise effects.
In certain embodiments the method further includes the steps of: sending, from the first device to the second device, timestamps which are the time of sending said packets from the first device according to a clock in the first device; and determining, for each packet in said group, the inter-departure time between the packet and the preceding packet from the first device, wherein an optimal inter-arrival time is determined for each packet as the inter-departure time between said packet and the preceding packet.
This selection of packets which most closely retain their inter-packet spacing from the transmitting device on arrival at the receiving device can be assumed to have experienced the minimum packet delay variation in their passage over the network.
The plurality of groups of packets may be discrete (i.e. have no overlapping members). In particular the groups of packets may be the packets which arrive within a sequence of time windows with each group starting with the first packet after the last packet in the previous window. Alternatively, the groups of packets may contain common packets. One particular implementation of the latter arrangement is where the groups are the packets arriving within a sequence of “sliding” windows each of which may include, for example, the final 75%, 50%, 25% or 10% of the previous window, plus a corresponding proportion of packets arriving after the end of the previous window.
In particular embodiments of this aspect, the packets are timing messages sent from a master device to a slave device over the packet network. Preferably the packets are timing messages sent under the IEEE 1588 Precision Time Protocol (PTP).
In such embodiments, the method may further include the step of using the selected packets in the synchronization of a clock in the slave device to a master clock in the master device.
Frequency and time synchronization play a very important role in mobile networks. For example, mobile wireless base stations derive their carrier radio frequencies from highly accurate reference clocks in the network. However, the primary challenge in the design of a clock synchronization system for packet networks is to deal with packet delay variations (PDVs)—that is, the variation of the packet transit delays. IEEE 1588 Precision Time Protocol (PTP) is now the protocol of choice in the communication industry for distributing timing information from a master to one or more slaves. A clock recovery mechanism is then used at receiver side for recovery of the master clock. PDV is the primary contributor to the noise in the recovered clock and various techniques are needed to mitigate its effect. The clock recovery problem becomes even more challenging in particular when timing information is sent in an end-to-end fashion from master to slave (without any form of timing assistance from the intermediate packet network). By using only the selected packets (i.e. those with low levels of PDV) in the synchronization of the slave clock, a more accurate synchronization may be achieved. The selected packets can be used together with a clock recovery mechanism to mitigate the effects of PDV and thus minimize the noise in the recovered clock at the slave. The resulting effect is that the slave may be able to recover the master clock to a higher quality as if the communication path between master and slave is free of PDV.
The method of the present aspect may include any combination of some, all or none of the above described preferred and optional features.
The methods of the above aspect is preferably implemented by a slave device according to the first aspect of this invention or in a system according to the third aspect of this invention, as described below, but need not be.
Further aspects of the present invention include computer programs for running on computer systems which carry out the methods of the above aspect, including some, all or none of the preferred and optional features of that aspect.
At their broadest, devices of the present invention provide a packet selection function which selects the packets arriving at the device which have characteristics closest to an optimal delay characteristic.
A second aspect of the present invention provides a first networked device connected to a second networked device over a packet network, wherein the first networked device has a clock and is arranged to: receive packets from the second device; record the time of receipt of said packets according to said clock; repeatedly, for each of a plurality of groups of said packets: determine an optimal inter-arrival time between successive packets at the first device; calculate, for each packet in said group, the inter-arrival time between the packet and the preceding packet; select the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time.
The networked device of this aspect can operate a packet (or message) selection technique that selects packets with low packet delay variation (PDV) or noise induced by their passage across the network. The selected packets can then be used by the first networked device for applications which require low noise characteristics, such as clock synchronization.
Preferably the repeated selection process in the device is performed by a processor in the device.
Preferably the groups of packets are all the packets arriving within a selected time window prior to the current time (i.e. the time at which the selection process runs).
In certain embodiments, the optimal inter-arrival time is determined as the mean of the inter-arrival times of the packets in the group.
In alternative embodiments, the optimal inter-arrival time is determined as the mean of the inter-arrival times of all packets received since a predetermined time equal to or prior to the receipt of the first packet in the group.
In these embodiments, a “running mean” of the inter-arrival times may be maintained or estimated by the method to avoid the need to calculate the mean afresh on the arrival of each packet or once all the packets in the group have been received. This results in a computationally efficient calculation of the optimal inter-arrival time. One particular example of such a running mean uses an exponentially weighted moving average of the inter-arrival times.
In other embodiments, the optimal inter-arrival time is determined as the median of the inter-arrival times of the packets in the group. In alternative embodiments, the optimal inter-arrival time is determined as the median of the inter-arrival times of all packets received since a predetermined time equal to or prior to the receipt of the first packet in the group.
Using a median rather than a mean may have advantages since it will be less influenced by outlier data points (values that are particularly small or large and therefore not typical of the data set as a whole) and skewed data. However, since the calculation of a median requires the storing of the inter-arrival time data for all packets which are to be used in the calculation of the median, the amount of such data is preferably limited to a selected “window” of packets prior to the time of the calculation.
The choice of the length of window may be varied depending on the situation. A longer window requires greater storage of previous values, and a more complex sorting operation to calculate the median. A shorter window runs the risk of not being statistically representative of the overall data set and being skewed by low frequency noise effects.
In certain embodiments, the first networked device is further arranged to: receive, from the second networked device, timestamps which are the time of sending said packets from the second device according to a clock in the second device; and determine, for each packet in said group, the inter-departure time between the packet and the preceding packet from the second device, wherein an optimal inter-arrival time is determined for each packet as the inter-departure time between said packet and the preceding packet.
This selection of packets which most closely retain their inter-packet spacing from the transmitting device on arrival at the receiving device can be assumed to have experienced the minimum packet delay variation in their passage over the network.
The plurality of groups of packets may be discrete (i.e. have no overlapping members). In particular the groups of packets may be the packets which arrive within a sequence of time windows with each group starting with the first packet after the last packet in the previous window. Alternatively, the groups of packets may contain common packets. One particular implementation of the latter arrangement is where the groups are the packets arriving within a sequence of “sliding” windows each of which may include, for example, the final 75%, 50%, 25% or 10% of the previous window, plus a corresponding proportion of packets arriving after the end of the previous window.
In particular embodiments of this aspect, the second networked device is a master device and the first networked device is a slave device and the packets are timing messages sent from the master device to the slave device over the packet network.
Preferably the packets are timing messages sent under the IEEE 1588 Precision Time Protocol (PTP).
In such embodiments, the first networked device may be further arranged to synchronize a clock in the first networked device to a master clock in the master device using the selected timing messages.
Frequency and time synchronization play a very important role in mobile networks. For example, mobile wireless base stations derive their carrier radio frequencies from highly accurate reference clocks in the network. However, the primary challenge in the design of a clock synchronization system for packet networks is to deal with packet delay variations (PDVs)—that is, the variation of the packet transit delays. IEEE 1588 Precision Time Protocol (PTP) is now the protocol of choice in the communication industry for distributing timing information from a master to one or more slaves. A clock recovery mechanism is then used at receiver side for recovery of the master clock. PDV is the primary contributor to the noise in the recovered clock and various techniques are needed to mitigate its effect. The clock recovery problem becomes even more challenging in particular when timing information is sent in an end-to-end fashion from master to slave (without any form of timing assistance from the intermediate packet network). By using only the selected packets with low levels of PDV in the synchronization of the slave clock, a more accurate synchronization may be achieved. The selected packets can be used together with a clock recovery mechanism to mitigate the effects of PDV and thus minimize the noise in the recovered clock at the slave. The resulting effect is that the slave is able to recover the master clock to a higher quality as if the communication path between master and slave is free of PDV.
The networked device of this aspect preferably operates by carrying out the relevant steps of a method according to the first aspect described above.
The networked device of the present aspect may include any combination of some, all or none of the above described preferred and optional features.
At their broadest, systems of the present invention provide a packet selection function which selects the packets transmitted from a first device to a second device which have characteristics closest to an optimal delay characteristic.
A third aspect of the present invention provides a networked system, the system including: a first networked device; a second networked device having a clock; and a packet network connecting the first and second devices, wherein the second networked device is arranged to: receive packets from the first device; record the time of receipt of said packets according to said clock; repeatedly, for each of a plurality of groups of said packets: determine an optimal inter-arrival time between successive packets at the second device; calculate, for each packet in said group, the inter-arrival time between the packet and the preceding packet; select the packet in said group which has an inter-arrival time which is the closest to the optimal inter-arrival time.
The system of this aspect can operate a packet (or message) selection technique that selects packets with low packet delay variation (PDV) or noise induced by their passage across the network. The selected packets can then be used by the second networked device for applications which require low noise characteristics, such as clock synchronization.
Preferably the repeated selection process in the second device is performed by a processor in that device.
Preferably the groups of packets are all the packets arriving within a selected time window prior to the current time (i.e. the time at which the selection process runs).
In certain embodiments, the optimal inter-arrival time is determined as the mean of the inter-arrival times of the packets in the group.
In alternative embodiments, the optimal inter-arrival time is determined as the mean of the inter-arrival times of all packets received since a predetermined time equal to or prior to the receipt of the first packet in the group.
In these embodiments, a “running mean” of the inter-arrival times may be maintained or estimated by the method to avoid the need to calculate the mean afresh on the arrival of each packet or once all the packets in the group have been received. This results in a computationally efficient calculation of the optimal inter-arrival time. One particular example of such a running mean uses an exponentially weighted moving average of the inter-arrival times.
In other embodiments, the optimal inter-arrival time is determined as the median of the inter-arrival times of the packets in the group. In alternative embodiments, the optimal inter-arrival time is determined as the median of the inter-arrival times of all packets received since a predetermined time equal to or prior to the receipt of the first packet in the group.
Using a median rather than a mean may have advantages since it will be less influenced by outlier data points (values that are particularly small or large and therefore not typical of the data set as a whole) and skewed data. However, since the calculation of a median requires the storing of the inter-arrival time data for all packets which are to be used in the calculation of the median, the amount of such data is preferably limited to a selected “window” of packets prior to the time of the calculation.
The choice of the length of window may be varied depending on the situation. A longer window requires greater storage of previous values, and a more complex sorting operation to calculate the median. A shorter window runs the risk of not being statistically representative of the overall data set and being skewed by low frequency noise effects.
In certain embodiments, the second networked device is further arranged to: receive, from the first networked device, timestamps which are the time of sending said packets from the first device according to a clock in the first device; and determine, for each packet in said group, the inter-departure time between the packet and the preceding packet from the first device, wherein an optimal inter-arrival time is determined for each packet as the inter-departure time between said packet and the preceding packet.
This selection of packets which most closely retain their inter-packet spacing from the transmitting device on arrival at the receiving device can be assumed to have experienced the minimum packet delay variation in their passage over the network.
The plurality of groups of packets may be discrete (i.e. have no overlapping members). In particular the groups of packets may be the packets which arrive within a sequence of time windows with each group starting with the first packet after the last packet in the previous window. Alternatively, the groups of packets may contain common packets. One particular implementation of the latter arrangement is where the groups are the packets arriving within a sequence of “sliding” windows each of which may include, for example, the final 75%, 50%, 25% or 10% of the previous window, plus a corresponding proportion of packets arriving after the end of the previous window.
In particular embodiments of this aspect, the first networked device is a master device and the second networked device is a slave device and the packets are timing messages sent from the master device to the slave device over the packet network.
Preferably the packets are timing messages sent under the IEEE 1588 Precision Time Protocol (PTP).
In such embodiments, the second networked device may be further arranged to synchronize a clock in the first networked device to a master clock in the master device using the selected timing messages.
Frequency and time synchronization play a very important role in mobile networks. For example, mobile wireless base stations derive their carrier radio frequencies from highly accurate reference clocks in the network. However, the primary challenge in the design of a clock synchronization system for packet networks is to deal with packet delay variations (PDVs)—that is, the variation of the packet transit delays. IEEE 1588 Precision Time Protocol (PTP) is now the protocol of choice in the communication industry for distributing timing information from a master to one or more slaves. A clock recovery mechanism is then used at receiver side for recovery of the master clock. PDV is the primary contributor to the noise in the recovered clock and various techniques are needed to mitigate its effect. The clock recovery problem becomes even more challenging in particular when timing information is sent in an end-to-end fashion from master to slave (without any form of timing assistance from the intermediate packet network). By using only the selected packets with low levels of PDV in the synchronization of the slave clock, a more accurate synchronization may be achieved. The selected packets can be used together with a clock recovery mechanism to mitigate the effects of PDV and thus minimize the noise in the recovered clock at the slave. The resulting effect is that the slave is able to recover the master clock to a higher quality as if the communication path between master and slave is free of PDV.
The system of this aspect preferably operates by carrying out a method according to the above described first aspect.
The system of the present aspect may include any combination of some, all or none of the above described preferred and optional features.
Packet selection techniques according to embodiments of the present invention will now be described.
Let T(n) denote the time base (e.g., in clock ticks) of the transmitter and R(n) the time base of the receiver. These two functions correspond to the timestamps of the two clocks at discrete time instants n, n=0, 1, 2, . . . . When timestamps are transmitted over the packet network, they will arrive at the receiver with variable delay. If d(n) and d(n−1) denote the delay experienced by the nth and (n−1) th timestamp at the receiver, respectively, then the delay variation induced by the network is given as j(n)=d(n)−d(n−1). The timestamp difference between the nth and (n−1) th generated timestamp at the transmitter is defined as ΔT(n)=T(n)−T(n−1). Taking the transmission of Sync messages at the master, for example, ΔT(n) can be calculated as ΔT(n)=T1(n)−T1(n−1).
At the receiver, the timestamp difference between the nth and n−1th timestamp arrivals measured by the receiver clock is defined as ΔR(n)=R(n)−R(n−1). Note that the timestamp difference measured by the receiver includes the delay variation (PDV) experienced between the two arrivals, that is:
ΔR(n)=ΔT(n)+j(n) (8)
where j(n) stands for nth sample's PDV. Again taking the reception of Sync messages at the slave, for example, ΔR(n) can be calculated as ΔR(n)=T2(n)−T2 (n−1).
A goal of the packet selection techniques described below is to select pairs of consecutive timing packets in such a way that the spacing between packets in each individual pair will be constant across all selected pairs (in the average sense) at the slave. Essentially, the goal is to present to the clock recovery mechanism a stream of timing packets that appear to depart from the master and arrive at the slave with no effects of delay variations. Timing packets that have constant spacing generate the least noise in the recovered clock at the slave.
Example Packet Selection Techniques
Two main techniques are described here, the first is based on extracting timing packets that create a constant spacing based on averaging ΔR(n), and the second is based on extracting the best packets that are the closest to satisfying the criterion ΔR(n)=ΔT(n).
Averaging of Inter-Arrival Times of Timing Messages
Let us consider the following equation
E[ΔR(n)]=E[ΔT(n)]+E[j(n)]=ΔT+μj, (9)
where E[•] is the expectation operator (mean), E[ΔT(n)]=ΔT is a constant for PTP transmissions, E[j(n)]=μj is the mean of j(n) which is not necessarily Gaussian. For a stationary distribution, the mean E[ΔR(n)] is a constant and thus can serve as the criterion for selecting the optimal (best) timing packets. The best packet in a window of packets is the packet closest to the mean value. The reason is that by selecting the packet closest to the mean value (which is a constant or almost a constant), we are selecting the packet with minimal PDV (i.e., the packet with minimal displacement from a reference mean position). These packets produce a stream of timing packets with near-constant inter-arrival times at the slave. The “residual PDVs” in this stream of near-constant spacing of timing packets can easily be handled by filtering process in the slave clock recovery mechanism as explained above. In practice, there are a number of ways of measuring E[ΔR(n)], like the running mean, median or mode.
The packet selection algorithm according to a first embodiment of the present invention, which will be called the “Mean of Inter-Arrival Times (MNIAT)”, is based on the running mean of ΔR(n). To estimate the running mean of the underlying distribution, we use the simple Exponentially Weighted Moving Average (EWMA) filter,
M(n)=α·ΔR(n)+(1−α)·M(n−1), 0<α<1 (10)
where α is the forgetting factor and M(n) is the mean estimate for nth time instant (or measurement window). The MNIAT algorithm minimizes the PDV by using the mean estimator M(n).
The packet selection algorithm according to a second embodiment of the present invention, which will be called the “Median of Inter-Arrival Times (MDIAT)”, is based on the median of ΔR values in a sampling window. We evaluate the Median of the underlying distribution as follows:
where L is the window length of ΔR values. The MDIAT algorithm minimizes the PDV by using the above median estimator.
Using either the MNIAT or MDIAT algorithms, the packet selection function g(xk) (see box 12 in
where xopt is the ΔR value of the selected packet, n is the discrete sampling time instant, L is the window size of ΔR samples, and xk is the k-th element in the packet selection window.
Measures of Central Tendency
A measure of central tendency is a single value that attempts to describe a set of data by identifying the central position within that set of data. As such, measures of central tendency are sometimes called measures of central location. They are also classed as summary statistics. The mean (often called the average) is most likely the measure of central tendency that people are most familiar with, but there are others, such as, the median and the mode. The mean, median and mode are all valid measures of central tendency but, under different conditions, some measures of central tendency become more appropriate to use than others.
Let us define an error variable as a difference between receiver and transmitter inter-arrivals as follows:
e(n)=ΔR(n)−ΔT(n)=j(n) (14)
e(n)→0ΔR(n)=ΔT(n) (15)
The packet selection function according to a third embodiment of the present invention, which will be called “Equalizing Inter-Departure and Inter-Arrival Times (EDAT)”, minimizes the effects of PDV by selecting timing messages such so that
e(n)=ΔR(n)−ΔT(n)=0 (16)
The best packet here is the one that minimizes the error variable as it minimizes the PDV as well. This is done by selecting the packet within a window of packets with difference between inter-arrival time and inter-departure time closest to the zero (ΔR(n)≈ΔT(n)) as this is the packet experiencing minimal PDV. These packets would thus best preserve the constant timing signal spacing at the transmitter.
The MNIAT, MDIAT and EDAT algorithms, which all share the same underlying idea, all allow for selecting the packet that minimizes the PDV. In the MNIAT, MDIAT and EDAT algorithms, the timestamps associated with the optimal packet in a window are captured then used in the slave clock recovery mechanism. A key advantage of using these techniques is that there is no need to switch between different packet selection criteria as is required in MMMA (see [1] for details) and moreover, the algorithms work for many other PDV distributions without any special handling.
Performance Evaluation of the MNIAT Algorithm
In this section the performance of the MNIAT algorithm is evaluated using the TDEV clock stability qualification metric. The following parameters are used in all tests: ensemble size is 10000 samples and τ0 is equal to one second. The
We can see from
Next the performance of the MNIAT algorithm is studied for different values of a (as shown in
Performance Evaluation of the MDIAT Algorithm
In this section the performance of the MDIAT algorithm is evaluated, again using the TDEV clock stability qualification metric.
We see from
From
Performance Evaluation of the EDAT Algorithm
In this section the performance of the EDAT technique is evaluated, again using the TDEV clock stability qualification metric. The results of EDAT and MNIAT (with α=0.01) are compared for different types of PDV distributions as shown in
The systems and methods of the above embodiments may be implemented in a computer system (in particular in computer hardware or in computer software) in addition to the structural components and user interactions described.
The term “computer system” includes the hardware, software and data storage devices for embodying a system or carrying out a method according to the above described embodiments. For example, a computer system may comprise a central processing unit (CPU), input means, output means and data storage. Preferably the computer system has a monitor to provide a visual output display (for example in the design of the business process). The data storage may comprise RAM, disk drives or other computer readable media. The computer system may include a plurality of computing devices connected by a network and able to communicate with each other over that network.
The methods of the above embodiments may be provided as computer programs or as computer program products or computer readable media carrying a computer program which is arranged, when run on a computer, to perform the method(s) described above.
The term “computer readable media” includes, without limitation, any non-transitory medium or media which can be read and accessed directly by a computer or computer system. The media can include, but are not limited to, magnetic storage media such as floppy discs, hard disc storage media and magnetic tape; optical storage media such as optical discs or CD-ROMs; electrical storage media such as memory, including RAM, ROM and flash memory; and hybrids and combinations of the above such as magnetic/optical storage media.
While the invention has been described in conjunction with the exemplary embodiments described above, many equivalent modifications and variations will be apparent to those skilled in the art when given this disclosure. Accordingly, the exemplary embodiments of the invention set forth above are considered to be illustrative and not limiting. Various changes to the described embodiments may be made without departing from the spirit and scope of the invention.
In particular, although the methods of the above embodiments have been described as being implemented on the systems of the embodiments described, the methods and systems of the present invention need not be implemented in conjunction with each other, but can be implemented on alternative systems or using alternative methods respectively.
All references referred to above are hereby incorporated by reference.
Aweya, James, Chaloupka, Zdenek
Patent | Priority | Assignee | Title |
9806876, | Mar 30 2015 | TELEFONAKTIEBOLAGET L M ERICSSON PUBL | Method and apparatus for compensating synchronization timing in a distributed timing network |
Patent | Priority | Assignee | Title |
20040264477, | |||
20050195749, | |||
20120102234, | |||
20120195253, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Oct 31 2013 | CHALOUPKA, ZDENEK | Emirates Telecommunications Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032035 | /0288 | |
Oct 31 2013 | CHALOUPKA, ZDENEK | British Telecommunications plc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032035 | /0288 | |
Oct 31 2013 | CHALOUPKA, ZDENEK | Khalifa University of Science, Technology, and Research | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032035 | /0288 | |
Nov 11 2013 | AWEYA, JAMES | Emirates Telecommunications Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032035 | /0288 | |
Nov 11 2013 | AWEYA, JAMES | British Telecommunications plc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032035 | /0288 | |
Nov 11 2013 | AWEYA, JAMES | Khalifa University of Science, Technology, and Research | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 032035 | /0288 | |
Dec 09 2013 | Emirates Telecommunications Corporation | (assignment on the face of the patent) | / | |||
Dec 09 2013 | British Telecommunications plc | (assignment on the face of the patent) | / | |||
Dec 09 2013 | Khalifa University of Science, Technology and Research | (assignment on the face of the patent) | / | |||
Feb 15 2017 | Khalifa University of Science, Technology and Research | KHALIFA UNIVERSITY OF SCIENCE AND TECHNOLOGY | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 050006 | /0773 |
Date | Maintenance Fee Events |
May 10 2016 | ASPN: Payor Number Assigned. |
Aug 05 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Aug 09 2023 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Feb 23 2019 | 4 years fee payment window open |
Aug 23 2019 | 6 months grace period start (w surcharge) |
Feb 23 2020 | patent expiry (for year 4) |
Feb 23 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Feb 23 2023 | 8 years fee payment window open |
Aug 23 2023 | 6 months grace period start (w surcharge) |
Feb 23 2024 | patent expiry (for year 8) |
Feb 23 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Feb 23 2027 | 12 years fee payment window open |
Aug 23 2027 | 6 months grace period start (w surcharge) |
Feb 23 2028 | patent expiry (for year 12) |
Feb 23 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |