The technology relates to the field of digital signal processing (DSP), and more specifically, to a digital clock smoothing apparatus and method.
A continuous receiver can only be utilized where generally continuous communications (as opposed to burst communications as in the present technology) are performed, so as to substantially maintain timing synchronization between the transmitter and the receiver which is necessary for proper reception of the communicated information. During continuous communications, timing recovery is a more straightforward process since signal acquisition generally only occurs at the initiation of such communications. Thus, acquisition is generally only performed in continuous receivers once per continuous transmission and each continuous transmission may be very long.
On the other hand, the burst communications (for instance, for TDMA systems) require periodic and frequent reacquisition of the signal. That is, during TDMA communications, the signal must be reacquired for each separate burst transmission being received.
This Summary is provided to introduce a selection of concepts that are further described below in the Detailed Description. This Summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
A method for digital clock smoothing is provided. The method comprises: (A) inputting an asynchronous data stream having an asynchronous symbol rate into a FIFO two-port memory block; (B) obtaining FIFO depth B by subtracting modulo B for each stored symbol a symbol output address from a symbol input address; (C) inputting FIFO depth B into a programmable look-up table (LUT); (D) obtaining a phase detector error signal; (E) scaling the phase detector error signal to obtain a scaled error factor, wherein the scaled error factor is normalized by using a set of parameters selected from the group consisting of: {a ratio of an input symbol rate to a reference clock; and a damping factor configured to compensate for latency of the frequency lock loop (FLL)}; (F) adding the scaled error factor to a nominal phase step to obtain a phase update; (G) obtaining a smoothed symbol rate; and (H) reading out each output symbol from FIFO under control of an output FIFO address control register at the smoothed symbol rate.
The accompanying drawings, which are incorporated in and form a part of this specification, illustrate embodiments of the technology and, together with the description, serve to explain the principles below:
Reference now be made in detail to the embodiments of the technology, examples of which are illustrated in the accompanying drawings. While the present technology will be described in conjunction with the various embodiments, it will be understood that they are not intended to limit the present technology to these embodiments. On the contrary, the present technology is intended to cover alternatives, modifications and equivalents, which may be included within the spirit and scope of the various embodiments as defined by the appended claims.
Furthermore, in the following detailed description, numerous specific-details are set forth in order to provide a thorough understanding of the presented embodiments. However, it will be obvious to one of ordinary skill in the art that the presented embodiments may be practiced without these specific details. In other instances, well known methods, procedures, components, and circuits have not been described in detail as not to unnecessarily obscure aspects of the presented embodiments.
In an embodiment of the technology,
In an embodiment of the present technology,
In an embodiment of the present technology, referring still to
To obtain an accurate count of symbols within the FIFO across the asynchronous clock domains (input vs. output clock), the output address is subtracted from the input address modulo B, where B is the FIFO depth. In one embodiment of the present technology, B=4096 as shown in
In an embodiment of the present technology, the phase detector error generator 50 is depicted in
In an embodiment of the present technology, referring still to
In an embodiment of the present technology, referring still to
In an embodiment of the present technology, the stored error value (12 bits) is further scaled by a binary power of 2 to compensate for the different baud rates (actually byte rates). If the binary power of 2 is in the range (0 to 10) for the scaling purposes, the actual scaling factor is in the range (1 to 1024). If one can make the range from 0 to 31 a 5-bit value will allow a complete 32-bit shift.
In an embodiment of the present technology, the scaling shifts are implemented by using a barrel shifter, i.e., a conditional shift by 16, followed by a conditional shift by 8, . . . , followed by a conditional shift of 1. The 12-bit error value starts in bit positions 31-20 with zero padding in positions 19-0. The scaling value 62 depends on the ratio of the symbol rate to the reference frequency. The scaled error 68 (32 bits) is further processed by the Loop Filter (LPF) 40 (of
In an embodiment of the present technology, the phase update block 90 is shown in
In an embodiment of the present technology, the two-stage phase accumulator 110 is depicted in
In an embodiment of the present technology, the N-stage phase accumulator 130 is depicted in
Referring still to
To compute the smoothing circuit values the following procedure is followed assuming a 186.667 MHz reference frequency (block 44 of
A. Phase Step.
The phase step is the value that sets the nominal frequency (natural frequency) out of the smoothing loop assuming no frequency updates. This frequency is computed as follows:
Phase Step=(Nominal Symbol Rate*Modulation Index*232)/(Reference Frequency*8). (Eq. 1)
The phase step given by (Eq.1) can be computed for different types of QAM modulations.
For BPSK modulation, whereas the modulation index is 1, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.125*232. (Eq.2)
For QPSK modulation, whereas the modulation index is 2, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.250*232. (Eq.3)
For 8 PSK modulation, whereas the modulation index is 3, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.375*232. (Eq.4)
For 16 PSK modulation, whereas the modulation index is 4, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.500*232. (Eq.5)
For 32 PSK modulation, whereas the modulation index is 5, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.625*232. (Eq.6)
For 64 PSK modulation, whereas the modulation index is 6, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.750*232. (Eq.7)
For 128 PSK modulation, whereas the modulation index is 7, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*0.875*232. (Eq.8)
Finally, for 256 PSK modulation, whereas the modulation index is 8, and where the symbol rate is in MHz, (Eq.1) can be re-written as follows:
Phase Step=(Nominal Symbol Rate/186.667)*1.000*232. (Eq.9)
If raw symbols are being output the 256QAM formula of (Eq.9) should be used.
B. Limit Check
The limit check is the value that clips updates to the frequency offset register to+Limit Check. The limit check is simply computed as the phase step multiplied by the maximum uncertainty allowed. Assuming the maximum uncertainty is 10−3, the limit check is computed as follows:
Limit Check=Phase Step*10−3, (Eq.10)
where, the phase step is given by (Eq.1).
C. Error Scale
The error scale is the value that is used to scale the phase detector curve based on baud rate. The error scale is computed as a ratio between the maximum symbol rate in use and the selected symbol rate. The scaling is performed as a power of 2 scaling. Since the maximum error value is set at +2047 in bit positions 31 through 20, it can scaled down by up to 31 right shifts with sign extension. The error value is related to the limit check so that the error value would not be a significant portion of the maximum frequency offset after scaling. Thus, the error value is damped considerably even at maximum error values. Assuming a damping factor β, the required scaling is computed as follows:
Error_Scale=(2047*220)/(Limit_Check*β). (Eq.11)
To obtain the number of right shifts the Log 2 (Error_Scale) is taken and rounded up to the nearest integer.
D. Creating Limit Masks.
Once the limit check value is computed its absolute value is rounded to the nearest power of 2. Two masks values are created: the first positive test mask is configured to test positive limits, and the second negative test mask is configured to test negative limits.
More specifically, the first positive test mask comprises all 1's in the 32 bit register down to the power of 2 position for the limit. The bit positions after the power of 2 limit are all 0's. The first positive test mask is logically added (AND'd) to the next frequency offset value. The result is tested for all 0's.
More specifically, the second negative test mask comprises all 0's in the 32 bit register down to the power of 2 position for the limit. The bit positions after the power of 2 limit are all 1's. The second negative test mask is logically multiplied (OR'd) with the next frequency offset value. The result is tested for all 1's.
If neither test is true then the limit has been exceeded. The MSB of the next frequency offset determines whether the limit will be set negative or positive. If the sign is positive, the next frequency offset value is set to the positive value of the limit check. If the sign is negative, the next frequency offset value is set to the negative value of the limit check.
One aspect of the present technology is directed to a method for digital clock smoothing.
In an embodiment of the present technology, the method of the present technology comprises (not shown): (A) inputting an asynchronous data stream having an asynchronous symbol rate into a two-port memory block; (B) accumulating a plurality of symbols of the asynchronous data stream in the two-port memory block for a predetermined time period long enough to accommodate the worst case burst and symbol offset; (C) computing an average symbol rate for the input asynchronous data stream; (D) generating a clock error signal equal to the difference between the average symbol rate of the input asynchronous data stream and a nominal output synchronous clock; (E) obtaining a smoothed symbol rate clock by using the error clock signal; and (F) generating an output smoothed data stream having the smoothed symbol rate clock.
In an embodiment of the present technology, the method comprises (not shown): (A) inputting an asynchronous data stream having an asynchronous symbol rate into a FIFO two-port memory block; (B) storing each input symbol in the FIFO under control of an input FIFO address control register; (C) obtaining a smoothed symbol rate; and (D) reading out each output symbol from the FIFO under control of an output FIFO address control register at the smoothed symbol rate.
The above discussion has set forth the operation of various exemplary systems and devices, as well as various embodiments pertaining to exemplary methods of operating such systems and devices. In various embodiments, one or more steps of a method of implementation are carried out by a processor under the control of computer-readable and computer-executable instructions. Thus, in some embodiments, these methods are implemented via a computer.
In an embodiment, the computer-readable and computer-executable instructions may reside on computer useable/readable media.
Therefore, one or more operations of various embodiments may be controlled or implemented using computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types. In addition, the present technology may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer-storage media including memory-storage devices.
Although specific steps of exemplary methods of implementation are disclosed herein, these steps are examples of steps that may be performed in accordance with various exemplary embodiments. That is, embodiments disclosed herein are well suited to performing various other steps or variations of the steps recited. Moreover, the steps disclosed herein may be performed in an order different than presented, and not all of the steps are necessarily performed in a particular embodiment.
Although various electronic and software based systems are discussed herein, these systems are merely examples of environments that might be utilized, and are not intended to suggest any limitation as to the scope of use or functionality of the present technology. Neither should such systems be interpreted as having any dependency or relation to any one or combination of components or functions illustrated in the disclosed examples.
Although the subject matter has been described in a language specific to structural features and/or methodological acts, the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as exemplary forms of implementing the claims.
This is a continuation of the U.S. patent application Ser. No. 11/357,685, entitled: “DIGITAL CLOCK SMOOTHING APPARATUS AND METHOD”, and filed on Feb. 18, 2006 now U.S. Pat. No. 7,613,211.
Number | Name | Date | Kind |
---|---|---|---|
4596026 | Cease et al. | Jun 1986 | A |
6381659 | Proch et al. | Apr 2002 | B2 |
6501809 | Monk et al. | Dec 2002 | B1 |
6714717 | Lowe et al. | Mar 2004 | B1 |
7613211 | Fagerlund et al. | Nov 2009 | B1 |
Number | Date | Country | |
---|---|---|---|
Parent | 11357685 | Feb 2006 | US |
Child | 12587266 | US |