The present invention relates in general to asynchronous communication systems and subsystems therefor, and is particularly directed to a new and improved digital phase locked loop (DPLL)-based adaptive clock recovery mechanism employed by the receiving entity of constant bit-rate (CBR) telecommunication signals transmitted over an asynchronous transfer mode (ATM) or ATM-like network, to achieve reliable voice and voice-band data communications in a manner that is effectively transparent to an associated modem serving customer premises equipment. The invention generates an output (recovered) clock based upon the DPLL's phase detector's count of the number of high frequency service clock cycles that occur between transitions in an input signal representative of instances of receipt of ATM cells written into a cell jitter buffer and subject to cell delay variations through the network, and a reference clock signal whose frequency is a prescribed fraction of that of the output clock.
The ability to conduct high-speed data and voice communications between remotely separated data processing systems and associated subsystems has become a requirement of a variety of industries and applications, such as business, educational, medical, financial and personal computer uses. Moreover, it can be expected that future applications of such communications will engender more systems and services in this technology. Associated with such applications has been the growing use and popularity of the “Internet”, which continues to stimulate research and development of advanced data communications systems between remotely located computers, especially communications capable of achieving relatively high-speed data rates over an existing signal transport infrastructure (e.g., legacy copper cable plant).
One technology that has gained particular interest in the telecommunication community is digital subscriber line (DSL) service, which enables a public service telephone network (PSTN) to deliver relatively high bandwidth signals (including voice and data) using conventional telephone company copper wiring infrastructure. DSL service has been categorized into several different technologies, based upon expected data transmission rate, the type and length of data transport medium, and encoding/decoding schemes.
Regardless of its application, the general architecture of a DSL network essentially corresponds to that diagrammatically shown in
For this purpose, at the network controller site 10, a DSL transceiver 11 is customarily located in a DSL access multiplexer (DSLAM) 12. Within the communication infrastructure of the telephone company, DSLAM 12 is coupled with the backbone 15, which typically contains one or more of signaling transport devices, such as an asynchronous transfer mode (ATM) switch 31, a voice gateway 33, a Class-5 switch 35, and the like, that are linked to an internet service provider (ISP) 37. Also a data gateway 36 may link the ATM switch 31 to a data network 38.
The other transceiver, serving the customer premises site 20, may comprise an integrated access device (IAD) 21, which is coupled via a plain old telephone system (POTS) interface 23 to a modem 25 (such as a V.90 modem) serving data terminal equipment (DTE) 27.
For transporting data and voice, an ATM network of the type shown in
To minimize or eliminate these disruptions, in order to effectively ensure reliable voice-band data transmission, it is necessary to remove the variable delay component of cell arrival time. This is customarily achieved through the use of a cell jitter buffer of sufficient length to accommodate maximum cell delay variation), and synchronizing the receive site's POTS interface (the IAD's CODEC) clock to the far-end or source site's transmitter clock, in a manner that avoids overflow or underflow of the buffer (which will occur if the clocks are not locked together).
One relatively straightforward method to recover the clock is to encode the transported ATM stream with a Synchronous Residual Time Stamp (SRTS) representative of the frequency difference between the source clock and a common reference network clock. At the receiving entity, the SRTS is decoded to regenerate the source clock frequency. Unfortunately, for AAL2-based data transmissions, physical layer timing on the DSL loop may not always be traceable to a primary reference source (transmit site) clock, and must be extracted ‘adaptively’ from the incoming AAL2 cell stream.
In an adaptive clock recovery scheme, no explicit timing information is transmitted from source to destination across the network and no common reference clock is used. Instead, source clock frequency information is derived by monitoring ATM cell arrival activity, and averaging out CDV effects. While there is currently no ‘standardized’ method, adaptive clock recovery has typically involved monitoring the ‘fill’ level of a cell jitter buffer, through which received ATM cells are controllably clocked by an associated clock recovery loop, and adjusting the receive entity clock, so that positions of write/read pointers to the buffer fall within a prescribed error window relative to a selected (e.g. median or statistically averaged) buffer fill level, and avoid overflow or underflow of the buffer.
For an illustration of non-limiting examples of literature describing various clock recovery schemes including both SRTS and buffer fill level-based adaptive mechanisms of the type described above, attention may be directed to the following U.S. Pat. Nos. 5,361,261, 5,844,891, 5,966,387, 6,111,878, 6,188,692 and 6,252,850.
In accordance with the present invention, adaptive clock recovery at the receiving entity is accomplished by means of a digital phase locked loop (DPLL), that is operative to generate an output (recovered) clock, based upon the DPLL's phase detector's count of the number of high frequency service clock cycles that occur between transitions in an input signal representative of instances of receipt of ATM cells written into the cell jitter buffer (and subject to cell delay variations through the network), and a reference clock signal whose frequency is a prescribed fraction of that of the output clock.
For this purpose, a cell jitter buffer and a second order DPLL, through which write and read pointers for the buffer are produced by associated control logic, have respective inputs coupled to receive signals associated with ATM (AAL2) cells as captured by the receiver's communications control processor from the xDSL link. The cell jitter buffer may be configured as a length L, first-in, first-out (FIFO) buffer, where L is greater than or equal to the maximum expected CDV. The cell jitter buffer stores the actual ATM cells, while the DPLL is coupled to receive a cell arrival interrupt signal Φin generated by the control processor as a respective cell is captured from the link. The DPLL also receives a high frequency (e.g., 40.96 MHz) service clock signal fs, which is used to set the phase adjustment step of the DPLL.
The DPLL's phase detector is coupled to receive the cell arrival interrupt signal Φin and a recovered output clock signal Φout derived from a controlled clock generator, which serves as the DPLL's voltage controlled oscillator function. The output of the phase detector is coupled to a (second order) loop filter which drives the clock generator. In accordance with the invention, the phase detector is implemented as an edge detector, by counting the number of clock cycles of the service frequency fs that occur between prescribed (e.g. rising edge) transitions of the input signal Φin and the DPLL's output clock signal Φout. The phase detector outputs a count-representative phase error signal Pe to the loop filter.
The second order loop filter includes first and second gain stages. The loop filter is coupled to a phase accumulator within the (VCO) clock generator. The clock generator is configured as an increment/decrement unit, that is coupled to the output of a service frequency clock generator and contains a divide-by-two output coupled to a divide-by-N1 frequency divider, where N1=10. As a result, for a reference service frequency fs=40.96 MHz, the output of the divide-by-N1 frequency divider produces a CODEC clock frequency of 2.048 MHz.
The output of divide-by-N1 frequency divider is further coupled to a divide-by-N2 (e.g., 22528) frequency divider and to a divide-by-N3 (e.g., 256) frequency divider. For these non-limiting parameters, the output of the divide-by-N2, which corresponds to the DPLL output clock signal Φout, with a nominal frequency of 90.909 Hz. The output of the divide-by-N3 frequency divider is 2048/256 KHz=8 KHz, which is the frequency of the byte read clock.
With both the phase detector and the loop filter running at 90.9090 Hz, a reasonably fast acquisition speed may be realized by running the VCO's phase accumulator and the clock generator at 128 KHz, as a non-limiting example. The period or time step T1 for the loop filter integrator is therefore T1= 1/90.9090 seconds, while the time step T2 for the (VCO) clock generator's integrator is T2= 1/128000 seconds.
In general, second order loop filter function F(S) may be expressed as: F(S)=α+β/S, while the system transfer function H(S) for Φout/Φin may be expressed as:
where K is VCO gain, and α and β are filter constants.
Equating the expression for H(S) with the standard expression for a second order control system yields:
where ζ is the damping factor of the loop and ωn is the natural frequency of the loop.
From this expression, the filter's gain coefficients α and β, which determine how rapidly the DPLL will track changes in the phase detector's error signal, can be derived as:
α=ω2n/K, and β=2*ζ*ωn/K.
From these expressions for α and β and a VCO gain K=1, expressions may be obtained for the DPLL's frequency and phase accumulators as: αd=T2*2*ζ*ωn, and βd=T1T2ω2n. Parameter settings for the DPLL depend upon respective operational modes: ACQUIRE, TRACK, FREEZE and FREE-RUN.
Incoming ATM AAL2 cells arrive at a prescribed periodic rate plus a cell delay variation, which is dynamic and unknown. Each newly arriving cell is written by the control processor into the cell jitter buffer at the address pointed to by the write pointer. The control processor then advances the write pointer and toggles the cell arrival interrupt signal, which is coupled to the phase detector of the DPLL. The control processor also reads out a cell byte from the address of the cell jitter buffer pointed to by the read pointer for each 8 KHz clock cycle. The cell jitter buffer read pointer is then advanced to the next cell byte stored in the buffer.
At the start of operation, the system is placed in ‘FREE-RUN’ mode, with system parameters set to FREE-RUN mode values. Incoming ATM cells are monitored for the start of a new voice/voice-band data call. When a new AAL2 cell is received, a determination is made as to whether the PLL is already locked. If so, the PLL transitions to ‘TRACK’ mode.
In TRACK mode, the loop filter's gain coefficients αd and βd are gradually reduced from their initial values to TRACK mode values, and the CODEC's clock input is switched from the free-running clock to the PLL's tracking clock. When the call is terminated, the routine transitions to FREEZE mode, wherein it stores the current value of frequency offset, so as to reduce the time required for the DPLL to acquire lock for the next incoming call. Otherwise the routine stays in TRACK mode.
If the PLL is not locked, the DPLL transitions to ACQUIRE mode. In this mode, the CODEC clock will have a large amount of jitter, due to high gain loop filter coefficients. To maintain high modem performance during data calls, a free-running clock is supplied to the CODEC. Once the DPLL is locked, the routine transitions to TRACK mode and proceeds as described above.
Before detailing the DPLL-based adaptive clock recovery scheme of the present invention, it should be observed that the present invention resides primarily in a prescribed set of conventional telecommunication signaling subsystems and components and attendant supervisory communications microprocessor circuitry, that controls the operations of such components. In a practical implementation that facilitates their incorporation into existing communication equipment, these arrangements may be readily configured as a field programmable gate array (FPGA)-implementation, application specific integrated circuit (ASIC) chip sets, programmable digital signal processors, or general purpose processors.
Consequently, the configuration of such components and the manner in which they are interfaced with other communication equipment of a telephone network have, for the most part, been illustrated in the drawings by readily understandable block diagrams, which show only those specific details that are pertinent to the present invention, so as not to obscure the disclosure with details which will be readily apparent to those skilled in the art having the benefit of the description herein. Thus, the block diagram illustrations of the Figures are primarily intended to show the major components of the system in a convenient functional grouping, whereby the present is invention may be more readily understood.
The cell jitter buffer 200 is preferably configured as a first-in, first-out (FIFO) buffer of length L cells, where L is greater than or equal to the maximum expected CDV. As a non-limiting example, the cell jitter buffer may have a length of eight ATM cells. Cell jitter buffer 200 receives and stores the actual ATM cells, while the digital PLL 210 is coupled to receive a cell arrival interrupt signal generated by the control processor as a respective cell is captured from the link. The interrupt can be generated by scanning an AAL2 cell header via software or hardware to detect a match in the channel of interest. The PLL 210 is also coupled to receive a local high frequency service clock signal fs (e.g., 40.96 MHz, for the parameters of the present example), which is used to set the phase adjustment step of the PLL, as will be described.
As a cell is received, it is controllably written into that storage location of the cell jitter buffer 200 pointed to by a ‘write’ pointer 202 as generated by a control logic circuit 220. In addition, the control logic circuit 220 is also coupled to generate a ‘read’ pointer 203 to define from which location in the cell jitter buffer 200 the next cell is to be extracted for delivery to the line card, as well as a CODEC clock.
A functional block diagram of the DPLL 210 is shown in
In accordance with the invention, the phase detector (PD) 300 functions as an edge detector, being operative to count the number of clock cycles of a reference (service) frequency fs (e.g., 40.96 MHz) that occur between prescribed transitions of the input signal Φin and the DPLL's output clock signal Φout. For example, as shown in the signal timing diagram of
The second order loop filter 320 includes a first gain stage 321 having a first loop filter gain coefficient ad and a second gain stage 322 having a second loop filter gain coefficient βd. The output of filter gain stage 321 is coupled to one input of a summation operator 323, whose output is the output of the loop filter. The output of the second gain stage 322 is coupled to one input of a frequency accumulator 326 formed of 324, the output of which is coupled to a second input of summation operator 323 and also over a delay feedback path containing a one stage delay 325 to a second input of summation operator 324.
The output of the loop filter 320 is coupled to one input of a summation operator 311 of a phase accumulator 315 within the clock generator 310. The output of the summation operator 311 is coupled to over a delay feedback path containing a one stage delay 312 to a second input of the summation operator 311, and to an increment/decrement control input 331 of a service frequency increment/decrement unit 330. Increment/decrement unit 330 has a clock input 332 coupled to the output of a service frequency clock generator (local oscillator) 340, and contains a divide-by-two output 333 coupled to a divide-by-N1 frequency divider 350. Implementing the VCO function as an increment/decrement of a high frequency service clock frequency has the advantage of not constraining/reducing the operation of (e.g., causing a training down or a dropping of the loop by) a high performance modem (such as a V.90 modem), and does not require the use of additional hardware (beyond arrangements, such as an FPGA and the like, referenced above).
In the present example, N1=10. As a result, for a reference service frequency fs=40.96 MHz, the output of divide-by-N1 frequency divider 750 is operative to produce a frequency of 40.96/(20) MHz=2.048 MHz (which corresponds to the frequency of the CODEC clock). The output of divide-by-N1 frequency divider 350 is further coupled to a divide-by-N2 frequency divider 360 and to a divide-by-N3 frequency divider 370. In the present example, N2=22528 and N3=256. As a result, the output of frequency divider 360, which corresponds to the DPLL output clock signal Φout, is 2.048/22528 MHz=90.9090 Hz., the period of which is the eleven millisecond interval, as shown in the clock signal timing diagram of
With both the phase detector 300 and the loop filter 320 running at 90.9090 Hz, a reasonably fast acquisition speed may be realized by running both the phase accumulator 315 and the clock generator 330 at 128 KHz, as a non-limiting example. The period or time step T1 for the loop filter integrator is therefore T1= 1/90.9090 seconds, while the time step T2 for the (VCO) clock generator's integrator is T2= 1/128000 seconds.
In general, second order loop filter function F(S) may be expressed in equation (1) as:
F(S)=α+β/S (1)
The system transfer function H(S) for Φout/Φin may be written in equation (2) as:
where K is VCO gain, and α and β are filter constants.
Equating equation (2) with the standard expression for a second order control system yields the following:
where ζ is the damping factor of the loop and ωn is the natural frequency of the loop.
From equation (3), the following expressions for the filter parameters α and β can be derived:
α=ω2n/K (4)
β=2*ζ*ωn/K (5)
For a critically damped system response ζ=21/2/2=0.707.
For an over-damped system response 0.707<ζ<2.
For an under-damped system response 0<ζ<0.707.
The natural frequency parameter ωn may be defined as:
ωn={2*BL}/{ζ+(¼ζ)}, (6)
where BL is the noise bandwidth of the loop.
Thus, filter parameters α and β determine how rapidly the PLL will track changes in the phase detector's error signal. At the start of a call, α and β are such that the system will acquire the source clock frequency fast enough to prevent the jitter buffer from overflowing or underflowing. However, once the transmitter clock has been acquired, α and β are (iteratively or stepwise) adjusted, so that the system will track slight changes in the source frequency and reject CDV noise.
Using the above expressions (4) and (5) for α and β and a VCO gain K=1, expressions are obtained for the DPLL's frequency and phase accumulators as:
αd=T2*2*ζ*ωn, and (7)
βd=T1T2ω2n (8)
For a critically damped loop (ζ=0.707), ωn=BL/0.53;
for BL=1 Hz, ωn=1.88 rad/sec.
βd=2.04×10−7, which is approximately equal to 2−21;
αd=2.1×10−5 or approximately 2−15.
The operation of the digital phase locked loop of
At step 701, system parameters are initialized to those shown in the Table of
In TRACK mode, the loop filter's gain coefficients αd and βd are gradually reduced from their initial values to TRACK mode values (see the Table of
Where the answer to ‘PLL already locked?’ query step 703 is NO (indicating that the PLL is not locked), the DPLL is switched to ACQUIRE mode in step 707. During ACQUIRE mode, the 2.048 MHz CODEC clock will have a large amount of jitter, due to the use of high gain loop filter coefficients, shown in the Tables of
As will be appreciated from the above description, being a totally digital implementation, the adaptive clock recovery scheme of the present invention is readily incorporated into the communication signal processor of the receiving entity for constant bit-rate (CBR) telecommunication signals transmitted over an asynchronous transfer mode (ATM) or ATM-like network. The digital phase locked loop (DPLL) produces a recovered clock based upon a phase detector's count of high frequency service clock cycles between transitions in an input signal representative of instances of receipt of ATM cells and a reference clock signal. This, in combination with a second order loop filter and digitally implementing the VCO function as an increment/decrement of a high frequency service clock frequency have the advantage of not impairing the operation of a high performance modem (such as a V.90 modem), and requiring no additional hardware.
While we have shown and described an embodiment in accordance with the present invention, it is to be understood that the same is not limited thereto but is susceptible to numerous changes and modifications as known to a person skilled in the art, and we therefore do not wish to be limited to the details shown and described herein, but intend to cover all such changes and modifications as are obvious to one of ordinary skill in the art.
Number | Name | Date | Kind |
---|---|---|---|
4706263 | von der Embse | Nov 1987 | A |
5361261 | Edem et al. | Nov 1994 | A |
5450447 | Dutta | Sep 1995 | A |
5784379 | Tan | Jul 1998 | A |
5844891 | Cox | Dec 1998 | A |
5966387 | Cloutier | Oct 1999 | A |
6111878 | Powell | Aug 2000 | A |
6188692 | Huscroft et al. | Feb 2001 | B1 |
6252850 | Lauret | Jun 2001 | B1 |
6819727 | Cucchi et al. | Nov 2004 | B1 |
6876674 | Ruutu et al. | Apr 2005 | B1 |
Number | Date | Country | |
---|---|---|---|
20030081550 A1 | May 2003 | US |