1. Field of the Invention
Embodiments of the present invention generally relate to methods of controlling the clock of a network element deployed within a communications network and, more specifically, to enhanced clock control in packet networks.
2. Description of the Related Art
In many telecommunications applications, each element in the network has its own clock (referred to herein as a “client clock”) running independently of the other clocks in the network. Quartz oscillators typically serve as client clocks in network elements, providing frequency to support local timescale generation. While quartz oscillators offer good frequency stability over short term measurement intervals, their intermediate and long term frequency stability does not meet the telecommunications standards. Therefore, client clocks must be checked and corrected against external traceable sources. Furthermore, given the immense number of elements in the network, the clock of each element is required to not only provide good frequency stability over all measurement intervals, but also be reproducible throughout the entire network with the lowest cost per element.
There are several means of providing timing information to client clocks at the client network elements. In legacy telecommunications networks, network elements utilized time-division multiplexing (TDM) links, such as T1 and SONET, which are inherently capable of carrying reliable frequency information from a server to a client at the physical layer. However, next generation networks may be based on a packet-switched infrastructure (such networks are referred herein as “packet networks”) and there may be situations where the physical medium interconnecting network elements is no longer capable of transporting frequency information at the physical layer. Therefore, packet-based methods for transporting timing information are required.
Even though a variety of timing sources may be available to the network element 100, not all timing sources are available in all cases. Also, their frequency stability is not always satisfactory for the telecommunications standard. The Multiple inputs Frequency Locked Loop (MiFLL) disclosed in U.S. Pat. No. 5,751,777 and U.S. Pat. No. 5,943,381, incorporated by reference above, achieves client clocks with good stability for any specified time measurement interval by optimally combining primary and secondary tier inputs. “Primary tier inputs” refer to timing information that comes over a verifiable (traceable) path from a known reliable timing source, such as the NTP server 110, the PTP server 120, or direct link sources 130. “Secondary tier inputs” originate from a better or equal stratum source than the local oscillator, but are not explicitly verifiable. The multicast NTP server 140 and multicast PTP server 150 could be used as secondary tier inputs, which would allow extracting time and frequency information with lower cost, lower power local oscillators without adding the burden of additional client transactions to the primary tier sources.
However, extracting time and frequency information from the multicast NTP and PTP flows creates several problems. First, it is not always known if these flows are sourced from a reliable server clock. Second, in practice, each packet in a flow experiences different delay with a significant random component, a phenomenon referred to as “packet delay variation” (PDV). As a result, inaccurate data may be sent to the MiFLL, compromising the performance of a client clock.
As the foregoing illustrates, what is needed in the art is a technique and apparatus for autonomously validating the time and frequency data obtained from multiple sources and generating a suitable estimates of the frequency differences between the client clock and the sources by mitigating the effects of PDV, so that only reliable data is sent to the MiFLL.
One embodiment of the present invention sets forth a method for autonomously validating the time and frequency information received from a server clock and generating a frequency estimate between a client clock and the server clock. The method includes the steps of receiving at least two protocol data units (PDUs), where each PDU includes a plurality of time stamps, extracting the plurality of time stamps from each PDU, and performing an offset measurement for each PDU to compute a time offset between the client clock and the server clock for each PDU, where each offset measurement is based on at least two of the time stamps associated with the PDU for which the offset measurement is being performed. The method also includes the steps of performing minimum offset filtering (MOF) on the time offsets to remove any time offsets that are based on invalid time stamp data and performing frequency estimate filtering (FEF) on the filtered time offsets to produce the frequency estimate and providing the frequency estimate to the MiFLL to achieve a good stability in the client clock for any specified time measurement interval.
One advantage of the disclosed methods is that control of the client clock may be achieved by using less trustworthy timing sources such as multicast NTP and multicast PTP servers to supplement the primary tier sources. The disclosed methods include the algorithms for cross-checking the measurement data obtained from the multicast NTP and multicast PTP servers, autonomously establishing validity of the channel, and concluding whether the current frequency estimate from a channel may be used in the MiFLL algorithm. As a result, time and frequency information at the client clocks can be extracted with lower cost, lower power oscillators without adding the burden to the primary tier sources, thereby reducing costs for both the servers and the clients.
So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.
The present invention improves upon the teachings of U.S. Pat. No. 5,751,777 and U.S. Pat. No. 5,943,381, the entire contents of both of which are incorporated herein by reference for all purposes.
T1 is a time stamp representing the best estimate of the transmit origination epoch of a protocol data unit (PDU) originating from the clock of a client 210,
T2 is a time stamp representing the best estimate of the receive termination epoch of a PDU terminating at the clock of a server 220,
T3 is a time stamp representing the best estimate of the transmit origination epoch of a PDU originating from the clock of the server 220, and
T4 is a time stamp representing the best estimate of the receive termination epoch of a PDU terminating at the clock of the client 210.
Each time stamp represents a critical epoch in a protocol transaction. Precise time stamps are typically conveyed in a single packet or, more generally, a single PDU, with the exception of PTP which supports the notion of a follow-up packet with a precise time stamp. Once the PDU is received at the client clock, the time stamps are used to generate an estimate of the frequency difference between the client clock and the originating source clock at the server, referred to herein as a “frequency estimate”. Furthermore, in the following description, the term “channel” is used to reference a particular server clock and an associated path and the term “outlier” is used to reference a timing source that is determined to be invalid.
Once the PDU is validated, the time stamp data 325 is provided to step 330, where an offset measurement is performed. Offset measurements for multicast one way measurements typically does not support any correction for propagation delay while two-way measurement include compensation with time accuracy limited by delay asymmetry in path. The offset measurement for one-way transfer operations, such as, for example, a packet or PDU flow originating at the clock of the server 220 and terminating at the clock of the client 210 is straight forward. In this case, the originating time stamp T3 is recorded with respect to the server view of time (server time scale) while the terminating time stamp T4 is recorded with respect to the client view of time (client time scale) and the measurement offset δm for a transaction n can be calculated as follows:
δm(n)=T4(n)−T3(n)
There are several important properties of the offset measurement. First property is that the offset measurement is biased by the one-way packet delay. The packet delay cannot be estimated with a one-way measurement. Second, the packet delay bias can be minimized by weighting measurements over a relatively short temporal frame with lower values. The packet flow models for a non-congested network support the notion that a minimum delay floor (discussed in more details in step 340) of a network can be effectively established. Finally, the residual bias can either be reduced by estimating the one-way delay through some other means, such as using time stamps associated with the reverse direction, or ignored in the case of frequency estimation as frequency offset is simply the rate of change of the phase offset, which is zero for a constant phase bias error.
From step 330, offset and validity data 335 is provided to step 340, where the minimum offset filter (MOF) pre-processes the offset data to extract data concentrated near the delay floor. This step significantly improves the resulting client clock performance. One property of packet networks is that packet delay variation has a distribution function with a “floor”. The floor is defined herein as the minimum delay that a packet or a PDU can experience in a given path. The floor can be viewed as a condition where both output and system queues (in all equipment that is involved in the flow, including the source, destination, and intervening elements) are near their minimum when a particular packet needs the resource. Under non-congested loading conditions a fraction of the total number of packets will traverse the network at or near this floor, even though others may experience significantly longer delays. In principle, floor-based transfer noise will have the minimum limited to the following four factors. First factor is the physical layer propagation “speed of light” delay. Second—is the time stamp resolution. Third—mapping delays over TDM-based transport. Finally, fourth limiting factor is other small delay variation mechanisms such as physical layer clock jitter and backplane clock domain jitter.
The MOF algorithm of step 340 utilizes data associated with each channel at time epoch n and channel measurement property data. The following data is associated with each channel at time epoch n:
δmi[n]: the measurement offset estimate with respect to the local oscillator of the ith channel at time index n;
δutmi[n]: the un-tilted measurement offset estimate of the ith channel at time index n;
δmini[n]: the minimum measurement offset estimate with respect to the local oscillator of the ith channel at time index n;
In_Validi[n]: the input validity flag of the ith channel at time index n; and
Out_Validi[n]: the output validity flag of the ith channel at time index n.
These five data elements are maintained in the MOF input buffer. Each buffer entry is indexed by the time epoch index (n). A circular buffer implementation is a preferred means to efficiently operate on the last N samples. The initialization condition is In_Valid [j] and Out Valid[j] is FALSE for all entries in the buffer.
The channel measurement property data for the MOF algorithm of step 340 is defined as follows:
bi: the input offset buffer sizing factor. Buffer depth is 2bi (=N) elements;
resi: the native timestamp resolution of the measurement (nanoseconds per lsb);
bufmini: the minimum number of valid buffer entries required to process a valid output;
tilti: the estimated tilt (in a native measurement resolution units) between successive offset samples; and
slewmof: the slew limiting factor to constrain outlier induced deviation from the floor 0<slewmof<1.
Using the variables defined above, the MOF algorithm of step 340 is as follows:
From step 340, minimum offset data 345 is provided to step 350, where a frequency estimate filter (FEF) performs a linear filtering process and generates the rate of change of phase delay (fractional frequency error) of a particular input channel with respect to the local oscillator. The output 375 of the FEF algorithm is a frequency estimate and an associated validity flag for the current channel. Persons skilled in the art will recognize that alternate linear filter structures can be utilized as well, without departing from the basic scope of the present invention. The FEF algorithm presented in this embodiment constitutes a computationally efficient operation.
The FEF algorithm of step 350 utilizes data associated with each channel at time epoch n and FEF data. The following data is associated with each channel at time epoch n:
δsmini[n]: the minimum smoothed measurement offset estimate with respect to the local oscillator of the ith channel at time index n;
fsmini[n]: the minimum smoothed frequency estimate with respect to the local oscillator of the i channel at time index n;
festi[n]: the output frequency estimate with respect to the local oscillator of the ith channel at time index n;
In_FEF_Validi[n]: the input validity flag of the ith channel at time index n; and
Out_FEF_Validi[n]: the output validity flag of the ith channel at time index n.
The five data elements defined are maintained if the FEF buffer. Each buffer entry is indexed by the time epoch index (n). A circular buffer implementation is a preferred means to efficiently operate on the last N samples. The initialization condition is In_FEF_Valid[j] and Out_FEF_Valid[j] is FALSE for all entries in the buffer.
The FEF data for the FEF algorithm of step 350 is defined as follows:
bi: the FEF buffer sizing factor. Buffer depth is 2bi (M) elements;
τsf: the first stage frequency filtering smoothing time constant; and
rest: the ratio parameter to control the time constant of the secondary stage frequency-smoothing filter.
Using the variables defined above, the FEF algorithm of step 350 is as follows:
The FC algorithm of step 360 utilizes data associated with each channel at time epoch n, defined as follows:
fi[n]: the frequency error estimate with respect to the local oscillator of the ith channel at time index n;
σ2i[n]: the Allan Variance estimate with respect to the local oscillator of the ith channel at time index n;
In_Validi[n]: the input validity flag of the ith channel at time index n;
Cluster_Validi[n]: the cluster validity flag of the ith channel at time index n; and
αci[n]: smoothing factor for the ith channel cluster Allan variance filter at time index n. (0<αmin<αc<αmax<1).
Using the variables defined above, the FC algorithm of step 360 is as follows:
Calculating an Allan Variance estimate is necessary to supporting the FC algorithm. The Allan Variance is a metric for estimating frequency stability of real-world random frequency processes. As described herein, the frequency estimation samples fi[n] are with respect to the local free-running oscillator. The MiFLL algorithms are based on allowing the local oscillator to operate in the free-run state. There is no necessity to varactor-steer the oscillator which will, in turn, introduce noise and non-linear effects. When varactor steering is employed the MiFLL algorithm is readily extended by utilizing an estimate of the steering correction to effectively obtain free-running data. The final output of the system is usually accomplished with digital frequency synthesis to compensate for the open loop (free-running) error in the local oscillator. In principle, the variance estimate would be biased by the oscillator noise over the integration time used for frequency estimation. For all practical cases, this excess oscillator noise is very small compared to the channel noise, and the local oscillator can be used as reference for the short term input noise calculation.
The Allan Variance estimates are only updated after the clustering algorithm is completed at time n. Only the valid set of m channels is updated. An Allan Variance sample is constructed for a channel as follows:
Si[n]=(fi[n]−fi[n−l])/2, and the Allan Variance is updated as: σ2i[n]=(1−αci[n])σ2i[n−1]+αci[n]S2i[n].
As previously described herein, αci[n] is the smoothing factor for the ith channel cluster Allan variance filter at time index n. The smoothing factor balances the responsiveness of the estimator to gradually changes in the noise level with the confidence interval of the estimator. The behavior is constrained by a global maximum and minimum value (0<αci[n]<αc<αmax<1). To support initially convergence αci is set to αmax and gradually reduced to αmin as follows:
αci[n]=(1αx)αci[n−1]+acαci[n], where ac is the global adaptation factor for the system.
At a channel re-initialization both αci is set to αmax and σ2i[n] is set to a global maximum level σ2cmax. All channels need to be initialized at the system startup. Also, after a persistent period of invalid condition (either input or cluster), the channel should be re-initialized.
The present invention enables a computing device to
One advantage of the disclosed methods is that control of the client clock may be achieved by using less trustworthy timing sources such as multicast NTP and multicast PTP servers to supplement the primary tier sources. The disclosed methods include the algorithms for cross-checking the measurement data obtained from the multicast NTP and multicast PTP servers, autonomously establishing validity of the channel, and concluding whether the current frequency estimate from a channel may be used in the MiFLL algorithm. As a result, time and frequency information at the client clocks can be generated with lower cost, lower power oscillators without adding the burden to the primary tier sources, thereby reducing costs for both the servers and the clients. Furthermore, the disclosed methods classify the various timing sources available in terms of “validity” and “suitability” and weigh them appropriately for use in the overall solution. Such a classification improves the outcome of the MiFLL algorithm because only the most reliable primary and secondary tier inputs are supplied to the MiFLL. In addition, the disclosed methods enable client clocks with good stability for the short term, intermediary, and long term measurement intervals that are easily reproducible throughout an entire network.
The present invention can be implemented in hardware or software, with the software being delivered as a program product for use with a computer system. The program(s) of the program product defines functions of the embodiments (including the methods described herein) and can be contained on a variety of computer-readable storage media. Illustrative computer-readable storage media include, but are not limited to: (i) non-writable storage media (e.g., read-only memory devices within a computer such as CD-ROM disks readable by a CD-ROM drive) on which information is permanently stored; (ii) writable storage media (e.g., floppy disks within a diskette drive or hard-disk drive) on which alterable information is stored. Such computer-readable storage media, when carrying computer-readable instructions that direct the functions of the present invention, are embodiments of the present invention.
While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof.
This application claims benefits of the U.S. provisional application Ser. No. 60/763,967, filed Feb. 1, 2006, which is herein incorporated by reference. This application is also related to U.S. Pat. No. 5,751,777 and U.S. Pat. No. 5,943,381, which are herein incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5812749 | Fernandez et al. | Sep 1998 | A |
6438702 | Hodge | Aug 2002 | B1 |
6650719 | Baker | Nov 2003 | B1 |
7130368 | Aweya et al. | Oct 2006 | B1 |
7415044 | Kallstenius | Aug 2008 | B2 |
20020136335 | Liou et al. | Sep 2002 | A1 |
20030048811 | Robie et al. | Mar 2003 | A1 |
20040093435 | Purho | May 2004 | A1 |
20040125822 | Jun et al. | Jul 2004 | A1 |
20060095553 | Ogawa et al. | May 2006 | A1 |
20060156011 | Masui | Jul 2006 | A1 |
20070061628 | Bradbury et al. | Mar 2007 | A1 |
Number | Date | Country | |
---|---|---|---|
20080049743 A1 | Feb 2008 | US |
Number | Date | Country | |
---|---|---|---|
60763967 | Feb 2006 | US |