The present disclosure relates to communication technologies, and more particularly to a method and device for improving clock stability.
In Circuit Emulation Services over Packet (CESoP), it is a key factor that influences the system performance to accurately recover a time division multiplex (TDM) service clock. For example, if a dedicated leased line is used between two clients connected by a circuit emulation service channel of the operator, clock frequencies of TDM services of the clients must be recovered precisely at the egress of the packet-based network. Otherwise, long-time frequency mismatch will result in overflow or read-empty of waiting queue at the egress of the packet-based network and cause slip impairment.
An adaptive approach is a common method for recovering clock, in which a receiving end extracts timing information from timestamps carried in packets and a packet arrival interval. This approach needs no extra reference clock, and is very suitable for use in a packet-based network. The process for adaptive clock recovery is shown in
The clock recovery needs both timestamps at the packet sending and reception, which inevitably introduces packet delay characteristics of the packet-based network. The key of the adaptive approach lies in how to effectively filter out the impairment of a packet delay variance (PDV) on the clock recovery so as to precisely recover the clock signal at the sending end.
The prior art provides a method for reducing the impairment of the PDV on the clock recovery. The method is as follows: outputting a write signal after performing traffic shaping on a received data packet; determining a data amount buffered in a first-in-first-out buffer according to the write signal and a read clock output by a digital oscillator; computing a filter parameter according to the write signal and the determined buffered data amount; and determining the recovered read clock according to the filter parameter.
In the implementation of the present disclosure, the inventors find that at least the following problems exist in the prior art.
The prior art reduces the impairment of the PDV on the clock recovery mainly by filtering. However, the change of timestamp intervals at the receiving end may be caused by various reasons, so that the filtering method is hardly suitable for different situations. Especially when a certain packet experiences a large delay in the network, a receiver timestamp (RT) is mutated, which seriously impairs the clock recovery.
The present disclosure is directed to a method and device for improving clock stability, so as to improve the stability of clock recovery.
A method for improving clock stability, comprising:
determining whether a difference between a current sender timestamp, ST, and a current receiver timestamp, RT, is a mutated value;
replacing the difference between the current ST and the current RT with an average difference between ST and the RT, if the difference between the current ST and current RT is a mutated value;
computing a new average difference between ST and the RT according to the replaced difference between the current ST and the current RT; and
acquiring a service clock according to the current ST, the current RT and the new average difference between ST and the RT.
A device for improving clock stability, comprising:
a determining unit, configured to determine whether a difference between a current sender timestamp, ST, and a current receiver timestamp, RT, is a mutated value;
a processing unit, configured to replace difference between the current ST and the current RT with an average difference between ST and the RT if the difference between the current ST and current RT is a mutated value;
the processing unit comprises:
a difference replacing subunit, configured to replace the difference between the current ST and the current RT by the average difference between ST and the RT stored in the detecting subunit when the determination result from the determining subunit is that the difference between the current ST and the current RT is a mutated value;
an average difference subunit, configured to compute an average difference between ST and the RT according to the difference between the current ST and the current RT replaced by the difference replacing subunit and update the average difference between ST and the RT stored in the detecting subunit when the determination result from the determining subunit is that the difference between the current ST and the current RT is a mutated value, or compute an average difference between the current ST and the current RT and update the average difference between the current ST and the current RT stored in the detecting subunit when the determination result from the determining subunit is that the difference between the current ST and the current RT is not a mutated value; and
a service clock acquiring unit, configured to acquire a service clock according to the current ST, the current RT and the average difference between ST and the RT from the processing unit.
A computer-readable medium, having computer usable instructions stored thereon for execution by a processor to perform a method for improving clock stability, comprising:
determining whether a difference between a current sender timestamp, ST, and a current receiver timestamp, RT, is a mutated value;
replacing the difference between the current ST and the current RT with an average difference between ST and the RT, if the difference between the ST and RT is a mutated value;
computing a new average difference between ST and the RT according to the replaced difference between the current ST and the current RT; and
acquiring a service clock according to the current ST, the current RT and the new average difference between ST and the RT.
In the embodiments of the present disclosure, a PDV may be smoothed, the impairment of the PDV on the clock recovery may be reduced, the quality of the clock recovery may be improved, and the problem of clock synchronization may be solved through the mutation processing on the timestamps.
To illustrate the technical solutions according to the embodiments of the present disclosure more clearly, the accompanying figures for describing the embodiments are introduced briefly in the following. Apparently, the accompanying drawings in the following description are some embodiments of the present disclosure; persons of ordinary skill in the art can derive other drawings according to the accompanying drawings without paying any creative efforts.
The embodiments of the present disclosure will be clearly and fully described below with reference to the accompanying drawings. It is obvious that the embodiments to be described are only a part rather than all of the embodiments of the present disclosure. All other embodiments derived by those skilled in the art based on the embodiments of the present disclosure described herein without paying any creative efforts fall within the scope of the present disclosure.
An embodiment of the present disclosure provides a method for improving clock stability, which may recover a service clock through an adaptive approach. As shown in
In Block s201, it is determined whether a difference between a current sender timestamp (ST) and a current receiver timestamp (RT) is a mutated value, and if yes, the ST and the RT are pre-processed.
The process for determining whether the difference between the current ST and the current RT (receiver/sender timestamp difference) is a mutated value is as follows. An amplitude of a difference between a current receiver/sender timestamp difference and an average receiver/sender timestamp difference is compared with a predetermined range to determine whether the amplitude exceeds the predetermined range, and if yes, it is detected whether amplitudes of differences between subsequent N receiver/sender timestamp differences and the average receiver/sender timestamp difference exceed the range. Here, N is a variable and can be flexibly configured according to demands of the algorithm. If the amplitudes of differences between the subsequent N receiver/sender timestamp differences and the average receiver/sender timestamp difference do not exceed the predetermined range, the current receiver/sender timestamp difference is a mutated value. If the amplitude of the difference between the current receiver/sender timestamp difference and the average receiver/sender timestamp difference does not exceed the predetermined range, the current receiver/sender timestamp difference is a non-mutated value. Or, if the amplitude of the difference between the current receiver/sender timestamp difference and the average receiver/sender timestamp difference exceeds the predetermined range, and the amplitudes of differences between the subsequent N receiver/sender timestamp differences and the average receiver/sender timestamp difference also exceed the predetermined range, the current receiver/sender timestamp difference is a non-mutated value.
The physical meaning of the receiver/sender timestamp difference (RT−ST) is a sum of an actual transmission delay (Delay) of a corresponding packet and an offset between clocks at receiving and sending ends (offset).
ΔT=RT−ST=Delay+offset
The change of either of the transmission delay (Delay) and the clock offset (offset) will result in the change of the timestamp difference. The possible reasons for the change of ΔT may be one or more of the following:
1) A queuing delay change caused by a change of the service load;
2) A retransmission delay change caused by multiple retransmissions in a Carrier Sense Multiple Access/Collision Detect (CSMA/CD) method;
3) A change of a packet transmission path; and
4) An adjustment of the execution time of the clock at the sending end.
The first three cases may result in the change of the packet transmission delay (Delay), while the last case may result in the change of the offset between the clocks at the receiving and sending ends (offset). Among them, only the first two cases may result in a mutation of the timestamp difference. The mutation of the timestamp difference indicates a small part of timestamp differences that seriously depart from the statistical regularity of the large part of timestamp differences among all timestamp differences. As shown in
When the difference is a mutated value, the ST and the RT are pre-processed. The pre-processing may be as follows. When the difference between the ST and the RT (receiver/sender timestamp difference) is a mutated value, the current receiver/sender timestamp difference corresponding to the current ST and the current RT is replaced with the average receiver/sender timestamp difference, and a new average receiver/sender timestamp difference is computed according to the replaced current receiver/sender timestamp difference. The pre-processed ST and RT include: the original ST, the original RT, and the new average receiver/sender timestamp difference.
In Block s202, a service clock is acquired according to the pre-processed ST and RT. A phase-locked computation is performed on the pre-processed ST, RT, and average receiver/sender timestamp difference to recover the service clock at the sending end.
In Block s203, TDM data is sent according to the service clock.
In this embodiment of the present disclosure, a packet delay variance (PDV) is smoothed, the impairment of the PDV on the clock recovery is reduced, the quality of the clock recovery is improved, and the problem of clock synchronization is solved through the mutation processing on the timestamps.
An embodiment, the present disclosure provides a method for improving clock stability, and the application background thereof is to recover a service clock by a self-adaptive method. As shown in
In Block s401, packet data is received, a current RT is recorded, and TDM data and STs (more than one ST) are separated from the packet data. The TDM data, the STs, and the RTs (more than one RT) are respectively stored in order from small to large STs, with one to one correspondence maintained among the TDM data, the STs, and the RTs. The STs, the RTs, and the TDM data are correspondingly stored in a timestamp buffer area and a data buffer area at the receiving end.
In Block s402, a data sending mechanism reads TDM data of a current packet from the data buffer area while finishing sending a previous data packet, and meanwhile, the timestamp buffer area sends the corresponding ST and RT to a determining and processing unit.
In Block s403, a mutated value of a difference between the current ST and the current RT is detected and repaired. It is determined whether the current difference between the ST and the RT is a mutated value, and if yes, the ST and the RT are pre-processed. An amplitude of a difference between a current receiver/sender timestamp difference and an average receiver/sender timestamp difference is compared with a predetermined range to determine whether the amplitude exceeds the predetermined range, and if yes, it is detected whether amplitudes of differences between subsequent N timestamp differences and the average receiver/sender timestamp difference exceed the predetermined range. If the amplitudes of differences between the subsequent N timestamp differences and the average receiver/sender timestamp difference do not exceed the predetermined range, the current receiver/sender timestamp difference is a mutated value. If the amplitude of the difference between the current receiver/sender timestamp difference and the average receiver/sender timestamp difference is within the predetermined range, or if the amplitude of the difference between the current receiver/sender timestamp difference and the average receiver/sender timestamp difference is not within the predetermined range, but the amplitudes of differences between the subsequent N timestamp differences and the average receiver/sender timestamp difference all exceed the predetermined range, the current receiver/sender timestamp difference is a non-mutated value. An average timestamp difference is computed according to a determination result.
In Block s404, a service clock is acquired according to the pre-processed ST and RT. A phase locked loop (PLL) receives the pre-processed timestamps, including the STs, the RTs, and the average receiver/sender timestamp difference, determines an amplitude of a frequency difference or phase difference between an output clock signal and a received clock signal according to the pre-processed ST and RT received, performs smooth filtering on the frequency difference or phase difference between the output clock signal and the received clock signal to filter out the influence of data change and other unstable factors on the whole module, performs an inversed phase modulation on the frequency or phase of the output clock signal according to the frequency difference or phase difference after smooth filtering, fixates the amplitude of the frequency difference or phase difference between the output clock signal and the received clock signal, and recovers the service clock at the sending end.
In Block s405, the data sending mechanism receives the service clock at the sending end recovered by the PLL, and is driven to push out a TDM bit stream according to the service clock.
The method for detecting and repairing a mutated value in Block s403 is shown in
In Block s501, an nth packet timestamp pair including an ST and an RT is received and detected, and a receiver/sender timestamp difference ΔTn of the nth packet timestamp pair is computed.
In Block s502, it is determined whether an amplitude of a difference between the receiver/sender timestamp difference ΔTn of the nth packet timestamp pair and an average receiver/sender timestamp difference ΔTaverage exceeds a predetermined range, and if yes, Block s503 is performed; otherwise, Block s507 is performed.
In Block s503, an mth (m=n+N) packet timestamp pair is detected, and a receiver/sender timestamp difference ΔTm of the mth packet timestamp pair is computed.
In Block s504, it is determined whether an amplitude of a difference between the receiver/sender timestamp difference ΔTm of the mth packet timestamp pair and the average receiver/sender timestamp difference ΔTaverage exceeds a predetermined range, and if yes, Block s505 is performed; otherwise, Block s508 is performed.
In Block s505, an mth (m=m−1) packet timestamp pair is detected.
In Block s506, it is determined whether m is greater than n, and if yes, Block s504 is performed to compute the receiver/sender timestamp difference ΔTm of the mth packet timestamp pair; otherwise, Block s507 is performed.
In Block s507, it is determined that the receiver/sender timestamp difference ΔTn of the nth packet timestamp pair is a non-mutated value, and an average receiver/sender timestamp difference is computed.
In Blocks s508, it is determined that the receiver/sender timestamp difference ΔTn of the nth packet timestamp pair is a mutated value, and the receiver/sender timestamp difference ΔTn of the nth packet timestamp pair is replaced by the average receiver/sender timestamp difference.
The method for improving clock stability according to the second embodiment of the present disclosure may smooth a PDV, reduce the impairment of the PDV on the clock recovery, improve the quality of the clock recovery, and solve the problem of clock synchronization by detecting mutated values of packets and performing a mutation processing on the timestamps.
In an embodiment, the present disclosure further provides a device for improving clock stability. As shown in
The determining unit 610 is configured to analyze timestamps from a buffer area, and determine whether an amplitude of a difference between a difference between a current ST and a current RT and an average receiver/sender timestamp difference exceeds a predetermined range, and if yes, detect whether amplitudes of differences between subsequent N receiver/sender timestamp differences and the average receiver/sender timestamp difference exceed the predetermined range. If the amplitudes of differences between the subsequent N receiver/sender timestamp differences and the average receiver/sender timestamp difference do not exceed the predetermined range, the difference between the ST and the RT is a mutated value. If the amplitude of the difference between the current receiver/sender timestamp difference and the average receiver/sender timestamp difference does not exceed the predetermined range or if the amplitude of the difference between the current receiver/sender timestamp difference and the average receiver/sender timestamp difference exceeds the predetermined range, but the amplitudes of differences between the subsequent N receiver/sender timestamp differences and the average receiver/sender timestamp difference all exceed the predetermined range, the current receiver/sender timestamp difference is a non-mutated value.
The processing unit 620 is configured to pre-process the current ST and the current RT according to a determination result from the determining unit 610, compute an average receiver/sender timestamp difference, and update the original average receiver/sender timestamp difference.
The service clock acquiring unit 630 is configured to compute the pre-processed ST, RT, and average receiver/sender timestamp difference, and recover a service clock at the sending end. The pre-processed ST and RT are involved in a phase-locked computation so as to recover the service clock at the sending end. The service clock acquiring unit 630 is configured to receive the timestamps, including the ST, the RT, and the average receiver/sender timestamp difference; determine an amplitude of a frequency difference or phase difference between an output clock signal and a received clock signal according to the pre-processed timestamps received after the mutated value pre-processing; perform smooth filtering on the frequency difference or phase difference between the output clock signal and the received clock signal to filter out the influence of data change and other unstable factors on the whole module; perform an inversed phase modulation on the frequency or phase of the output clock signal according to the output frequency difference or phase difference; fixate the amplitude of the frequency difference or phase difference between the output clock signal and the received clock signal, and recover the service clock at the sending end.
The data sending unit 640 is configured to send a TDM bit stream according to the clock signal recovered by the service clock acquiring unit 630.
The structure of the determining unit 610 is shown in
The receiving subunit 611 is configured to receive the timestamps including an ST and an RT from a data receiving unit 650.
The detecting subunit 612 is configured to detect whether an amplitude of a difference between a current receiver/sender timestamp difference and an average receiver/sender timestamp difference is within a predetermined range according to the timestamp pair received by the receiving subunit 611 and the average receiver/sender timestamp difference stored in the detecting subunit 612, and send a detection result to the determining subunit 613.
The determining subunit 613 is configured to determine whether the current receiver/sender timestamp difference is a mutated value according to the detection result from the detecting subunit 612.
The structure of the service clock acquiring unit 630 is shown in
The phase discrimination subunit 631 is configured to receive the pre-processed timestamps, including the ST, the RT, and the average receiver/sender timestamp difference, and determine an amplitude of a frequency difference or phase difference between an output clock signal and a received clock signal according to the pre-processed timestamps received.
The filtering subunit 632 is configured to perform smooth filtering on the frequency difference or phase difference between the output clock signal and the received clock signal from the phase discrimination subunit 631 to filter out the influence of data change and other unstable factors on the whole module.
The phase modulation subunit 633 is configured to perform an inversed phase modulation on the frequency or phase of the output clock signal according to the frequency difference or phase difference output from the filtering subunit 632, fixate the amplitude of the frequency difference or phase difference between the output clock signal and the received clock signal, and recover the service clock at the sending end.
A device for improving clock stability according to the embodiment of the present disclosure further includes a data receiving unit 650, configured to receive packet data, record RTs, separate TDM data and STs, send the TDM data to the data sending unit 640, and send the STs and the RTs to the determining unit 610. The STs, the RTs, and the TDM data are respectively stored in a timestamp buffer area and a data buffer area correspondingly. The TDM data and the timestamps are stored in order from small to large STs, with one to one correspondence maintained among the TDM data, the STs, and the RTs. The sorting mechanism can effectively reduce the impairment of packet disorder on the clock recovery.
An embodiment of the present disclosure further provides an apparatus for improving clock stability. As shown in
The determining module 710 is configured to determine whether a difference between a current ST and a current RT is a mutated value.
The processing module 720 is configured to pre-process the ST and the RT according to a determination result from the determining module 710.
The service clock acquiring module 730 is configured to acquire the service clock according to the ST and the RT pre-processed by the processing module 720.
The determining module 710 further includes a receiving sub-module 711, a detecting sub-module 712, and a mutated value determining sub-module 713.
The receiving sub-module 711 is configured to receive the ST and the RT from the data receiving apparatus.
The detecting sub-module 712 is configured to detect whether an amplitude of a difference between a current receiver/sender timestamp difference and an average receiver/sender timestamp difference is within a predetermined range according to the ST and the RT received by the receiving sub-module 711 and the average receiver/sender timestamp difference stored in the detecting sub-module 712.
The mutated value determining sub-module 713 is configured to determine whether the current receiver/sender timestamp difference is a mutated value according to a detection result sent by the detecting sub-module 712.
The processing module 720 may further include a difference processing sub-module 721.
The difference processing sub-module 721 is configured to compute an average receiver/sender timestamp difference according to a determination result from the mutated value determining sub-module 713 and update the average receiver/sender timestamp difference stored in the detecting sub-module 712.
Alternatively, the processing module 720 may further include a difference replacing sub-module and an average difference sub-module.
The difference replacing sub-module is configured to replace the current receiver/sender timestamp difference by the average receiver/sender timestamp difference stored in the detecting sub-module 712 when a determination result from the mutated value determining sub-module 713 is that the current receiver/sender timestamp difference is a mutated value.
The average difference sub-module is configured to compute an average receiver/sender timestamp difference according to the current receiver/sender timestamp difference replaced by the difference replacing sub-module and update the average receiver/sender timestamp difference stored in the detecting sub-module 712 when the determination result from the mutated value determining sub-module 713 is that the current receiver/sender timestamp difference is a mutated value, or compute an average receiver/sender timestamp difference and update the average receiver/sender timestamp difference stored in the detecting sub-module 712 when the determination result from the mutated value determining sub-module 713 is that the current receiver/sender timestamp difference is not a mutated value.
The service clock acquiring module 730 further includes a phase discrimination sub-module 731, a filtering sub-module 732, and a phase modulation sub-module 733.
The phase discrimination sub-module 731 is configured to receive the preprocessed timestamps from the processing module 720, and determine an amplitude of a frequency difference or phase difference between an output clock signal and a received clock signal.
The filtering sub-module 732 is configured to perform smooth filtering on the frequency difference or phase difference output from the phase discrimination sub-module 731.
The phase modulation sub-module 733 is configured to perform an inversed phase modulation on the frequency or phase of the output clock signal according to the frequency difference or phase difference output from the filtering sub-module 732, and fixate the amplitude of the frequency difference or phase difference between the output clock signal and the receive clock signal.
The modules mentioned above may be distributed in one or more apparatuses. The modules may be integrated into one module, or be further divided into a plurality of sub-modules.
The apparatus according to the embodiments of the present disclosure may smooth a PDV, reduce the impairment of the PDV on the clock recovery, improve the quality of the clock recovery, and solve the problem of clock synchronization by the performing a mutation processing on the timestamps.
Through the description of the implementations, it is clear to those skilled in the art that the present disclosure may be implemented through hardware, or through software and a necessary universal hardware platform. Based on the above, the technical solutions of the present disclosure may be embodied in the form of a software product. The software product may be stored in a nonvolatile storage media (for example, CD-ROM, USB flash drive, or removable hard disk) and contain several instructions configured to instruct a computer device (for example, a personal computer, a server, or network device) to perform the method according to the embodiments of the present disclosure.
It should be understood by those skilled in the art that the accompanying drawings are schematic views of the preferred embodiments, and modules or processes in the accompanying drawings may not be necessarily required in the implementation of the present disclosure.
It should be understood by those skilled in the art that, modules in a device according to an embodiment may be distributed in the device of the embodiment as described above, or be correspondingly changed to be disposed in one or more devices different from this embodiment. The modules of the embodiments may be integrated into one module, or further divided into a plurality of sub-modules.
The sequence numbers of the embodiments of the present disclosure are merely for the convenience of description, and do not imply the preference among the embodiments.
Several specific embodiments of the present disclosure are described above, and the present disclosure is not limited thereto. Any variations that can be easily thought of by those skilled in the art should fall within the scope of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
2008 1 0211970 | Sep 2008 | CN | national |
PCT/CN2009/071506 | Apr 2009 | WO | international |
This application is a continuation of U.S. patent application Ser. No. 12/501,861, filed on Jul. 13, 2009, which claims priority to Chinese Patent Application No. 200810211970.0, filed on Sep. 12, 2008, and International Patent Application No. PCT/CN2009/071506, filed on Apr. 27, 2009, all of which are hereby incorporated by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
6819685 | Abouchakra et al. | Nov 2004 | B1 |
7020791 | Aweya et al. | Mar 2006 | B1 |
7079554 | Peled | Jul 2006 | B2 |
7106823 | Miller et al. | Sep 2006 | B2 |
7191355 | Ouellette et al. | Mar 2007 | B1 |
7289538 | Paradise et al. | Oct 2007 | B1 |
7411970 | Scott et al. | Aug 2008 | B2 |
7415044 | Kallstenius | Aug 2008 | B2 |
7474624 | Grossman | Jan 2009 | B2 |
7711009 | Kataria et al. | May 2010 | B2 |
7817673 | Scott et al. | Oct 2010 | B2 |
20060233203 | Iwamura | Oct 2006 | A1 |
20070104228 | Cohen et al. | May 2007 | A1 |
20070223459 | Crowle et al. | Sep 2007 | A1 |
20100067552 | Sun et al. | Mar 2010 | A1 |
Number | Date | Country |
---|---|---|
1496072 | May 2004 | CN |
1551556 | Dec 2004 | CN |
1581845 | Feb 2005 | CN |
1394975 | Aug 2003 | EP |
Number | Date | Country | |
---|---|---|---|
20110058576 A1 | Mar 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12501861 | Jul 2009 | US |
Child | 12938123 | US |