Skew compensation based on equalizer coefficients

Information

  • Patent Grant
  • 9036751
  • Patent Number
    9,036,751
  • Date Filed
    Thursday, January 17, 2013
    11 years ago
  • Date Issued
    Tuesday, May 19, 2015
    9 years ago
  • CPC
  • US Classifications
    Field of Search
    • US
    • 375 295000
    • 375 299000
    • 375 316000
    • 375 320000
    • 375 322000
    • 375 330000
    • 375 336000
    • 375 340000
    • 375 342000
    • 375 345000
    • 375 346000
    • 375 350000
    • 375 354000
    • CPC
    • G11B27/36
    • G11B7/007
    • H04B10/697
    • H04B1/3833
    • H04L2025/03535
    • H04L2027/004
    • H04L2027/0067
    • H04L25/03019
    • H04L27/0014
    • H04L27/01
    • H04L27/223
    • H04L27/3818
    • H04L25/03057
    • H04L2025/0349
    • H04L2025/03503
    • H04L2025/03611
    • H04L25/03038
    • H04L25/061
    • H04L7/0029
    • H04L7/027
    • H04L2025/03477
    • H04L2025/03515
    • H04L2025/03617
  • International Classifications
    • H04B1/10
    • H04L27/01
Abstract
A receiver applies a calibration method to compensate for skew between input channels. The receiver skew is estimated by observing the coefficients of an adaptive equalizer which adjusts the coefficients based on time-varying properties of the multi-channel input signal. The receiver skew is compensated by programming the phase of the sampling clocks for the different channels. Furthermore, during real-time operation of the receiver, channel diagnostics is performed to automatically estimate differential group delay and/or other channel characteristics based on the equalizer coefficients using a frequency averaging or polarization averaging approach. Framer information can furthermore be utilized to estimate differential group delay that is an integer multiple of the symbol rate. Additionally, a DSP reset may be performed when substantial signal degradation is detected based on the channel diagnostics information.
Description
BACKGROUND

1. Field of the Art


The disclosure relates generally to communication systems, and more specifically, to using equalizer coefficients to improve performance and diagnostics in an optical receiver system.


2. Description of the Related Art


Optical communication systems typically communicate data over a plurality of channels corresponding to different phases and/or polarizations of the optical signal. For example, in a dual-polarization coherent optical communication system, data is communicated over four channels: (1) a horizontally polarized in-phase (HI) channel; (2) a horizontally polarized quadrature (HQ) channel; (3) a vertically polarized in-phase (VI) channel; and (4) a vertically polarized quadrature (VQ) channel. While the data communicated over the different channels is typically aligned relative to a common clock when transmitted by the transmitter, delay (or skew) may be introduced into one or more of the channels based on characteristics of the transmitter, receiver, and/or the optical fiber. As a result, the relative timing of the data in the various channels may be misaligned at the receiver, causing degradation of the recovered data.


SUMMARY

A system performs automatic skew calibration to compensate for skew between different input channels. An analog-to-digital converter converts an analog signal vector to a digital signal vector. The analog signal vector has a plurality of channels. The analog-to-digital converter samples each of the plurality of channels based on a corresponding sampling clock. A skew compensation block generates the corresponding sampling clocks for each of the plurality of channels based on skew compensation values specifying an amount of skew compensation for each of the plurality of channels. An adaptive equalizer equalizes the digital signal vector. The adaptive equalizer furthermore adaptively updates coefficients based on characteristics of the digital signal vector and generates an equalized signal vector. A skew estimator obtains the coefficients of the adaptive equalizer and determines an amount of skew between at least two of the plurality of channels. The skew estimator then programs the skew compensation block with the skew compensation values based on the determined amount of skew.


In one embodiment of a calibration process, a receiver sets a first skew compensation value for a first channel to a first value for testing and sets a second skew compensation value for a second channel to a second skew value for testing. The first and second skew compensation values control an amount of skew compensation in their respective channels. The receiver obtains coefficients of an adaptive equalizer when operating the receiver using the first and second skew compensation values. A skew metric is computed that approximates a skew between the first and second channel based on the obtained coefficients of the adaptive equalizer. At least one of the first skew compensation value for the first channel and the second skew compensation value for the second channel is adjusted based on the skew metric.





BRIEF DESCRIPTION OF THE DRAWINGS

The invention has other advantages and features which will be more readily apparent from the following detailed description of the invention and the appended claims, when taken in conjunction with the accompanying drawings, in which:



FIG. 1 is a block diagram illustrating an embodiment of an optical communication system.



FIG. 2A is a block diagram illustrating a first embodiment of system for performing skew calibration.



FIG. 2B is a block diagram illustrating a second embodiment of system for performing skew calibration.



FIG. 3 is a graph illustrating an example of filter coefficients that indicate the presence of skew between an in-phase channel and a quadrature channel.



FIG. 4A is a flowchart illustrating a first embodiment of a skew calibration process using a correlation approach.



FIG. 4B is a flowchart illustrating a second embodiment of a skew calibration process using a center of gravity and correlation approach.



FIG. 5 is a flowchart illustrating a n embodiment of a skew calibration process for compensating for skew between horizontal and vertical polarizations.



FIG. 6 is a flowchart illustrating an embodiment of a process for detecting differential group delay based on frequency coefficients and framer information.



FIG. 7A is a flowchart illustrating a first embodiment of a process for resetting a digital signal processor when substantial performance degradation is detected.



FIG. 7B is a flowchart illustrating a second embodiment of a process for resetting a digital signal processor when substantial performance degradation is detected.



FIG. 8 is a block diagram illustrating an embodiment of an optical communication system having a polarization scrambler.



FIG. 9 is a flowchart illustrating an embodiment of a process for detecting differential group delay based on frequency coefficients in an optical communication system that uses polarization scrambling.



FIG. 10A is a block diagram illustrating a first example architecture of data and channel estimation paths for DGD estimation using polarization averaging.



FIG. 10B is a block diagram illustrating a second example architecture of data and channel estimation paths for DGD estimation using polarization averaging.





DETAILED DESCRIPTION

Overview


The disclosed embodiments generally relate to improving performance of coherent communication systems that employ electronic equalization of communication channels in the receiver. In a first aspect, a receiver performs an automatic skew calibration to compensate for skew between different input channels during a calibration stage of the receiver. The receiver skew is estimated by observing the coefficients of an adaptive equalizer, which adjusts the coefficients based on time-varying properties of the multi-channel input signal. The receiver compensates for the estimated skew by adjusting the phases of the sampling clocks for the different channels.


In a second aspect, the receiver performs channel diagnostics to extract channel information from the equalizer coefficients. The channel information can be used to automatically estimate differential group delay introduced by channel impairments during real-time operation. The differential group delay is accurately estimated based on the equalizer coefficients using a frequency averaging approach. Framer information can furthermore be utilized to estimate differential group delay that is an integer multiple of the symbol rate. The diagnostics information may also be used to reset the device when substantial performance degradation is detected.


High Level System Architecture



FIG. 1 is a block diagram of a communication system 100. The communication system 100 comprises a transmitter 110 for encoding data as an electrical signal, an optical transmitter 120 for converting the electrical signal produced by the transmitter 110 to an optical signal suitable for transmission over a communication channel 130, an optical front end 150 for converting the received optical signal to an electrical signal, and a receiver 160 for receiving and processing the electrical signal encoding the data from the optical front end 150. Optionally, a separate processor 180 may be coupled to the receiver 160 to perform skew calibration and channel diagnostics as will be described below. In one embodiment, the communication system 100 comprises an ultra-high speed (e.g., 40 Gb/s or faster) optical fiber communication system, although the described techniques may also be applicable to lower speed optical communication systems.


The transmitter 110 comprises a transmitter (Tx) framer 111, an encoder 112, a modulator 114, a Tx digital signal processor (DSP) 116, and a Tx analog front end (AFE) 118. The Tx framer 111 receives input data 105 from a host interface and formats the data for processing by the transmitter 110. The encoder 112 encodes the framed data for transmission over the optical network. For example, in one embodiment, the encoder 112 encodes the input data 105 using forward error correction (FEC) codes that will enable the receiver 160 to detect, and in many cases, correct errors in the data received over the channel 130. The modulator 114 modulates the encoded data via one or more carrier signals for transmission over the channel 130. For example, in one embodiment, the modulator 114 applies phase-shift keying (PSK) or different phase-shift keying (DPSK) to the encoded data. The Tx DSP 116 adapts (by filtering, etc.) the modulator's output signal according to the channel characteristics in order to improve the overall performance of the transmitter 110. The Tx AFE 118 further processes and converts the Tx DSP's digital output signal to the analog domain before it is passed to the optical transmitter (Optical Tx) 120 where it is converted to an optical signal and transmitted via the channel 130. One example of the optical transmitter 120 transmits independent modulations on both polarizations of the optical carrier. Example modulations are binary phase shift keying (BPSK) and quadrature phase-shift keying (QPSK), though other modulations can be used, and the choice can be made to transmit on either one or both polarizations. Additional example modulations include differential BPSK (DBPSK) and differential QPSK (DQPSK).


In addition to the illustrated components, the transmitter 110 may comprise other conventional features of a transmitter 110 which are omitted from FIG. 1 for clarity of description. Furthermore, in one embodiment, the transmitter 110 is embodied as a portion of a transceiver device that can both transmit and receive over the channel 130.


The channel 130 may have a limited frequency bandwidth and may act as a filter on the transmitted data. Transmission over the channel 130 may add noise to the transmitted signal including various types of random disturbances arising from outside or within the communication system 100. Furthermore, the channel 130 may introduce fading and/or attenuation effects to the transmitted data. Additionally, the channel 130 may introduce chromatic dispersion (CD) and polarization mode dispersion (PMD) effects that cause a distortion of the signals transmitted through the channel 130.


The optical front end 150 receives the optical signal from the channel 130, converts the optical signal to an electrical signal, and passes the electrical signal to the receiver 160. The receiver 160 receives the encoded and modulated data from the transmitter 110 via the optical transmitter 120, communication channel 130, and optical front end 150, and produces recovered data 175 representative of the input data 105. The receiver 160 includes a receiver (Rx) analog front end (AFE) 168, an RX DSP 166, a demodulator 164, a decoder 162, and an Rx framer 163. The Rx AFE 168 samples the analog signal from the optical front end 150 based on a clock signal 181 to convert the signal to the digital domain. The Rx DSP 166 further processes the digital signal by applying one or more filters to improve signal quality. The demodulator 164 receives the modulated signal from the Rx DSP 166 and demodulates the signal. The decoder 162 decodes the demodulated signal (e.g., using error correction codes). The Rx framer 163 aligns and formats the decoded data for synchronization with a host interface that receives the recovered input data 105.


In addition to the illustrated components, the receiver 160 may comprise other conventional features of a receiver 160 which are omitted from FIG. 1 for clarity of description. Furthermore, in one embodiment, the receiver 160 is embodied as a portion of a transceiver device that can both transmit and receive over the channel 130.


Components of the transmitter 110 and the receiver 160 described herein may be implemented, for example, as an integrated circuit (e.g., an Application-Specific Integrated Circuit (ASIC) or using a field-programmable gate array (FPGA), in software (e.g., loading program instructions to a processor (e.g., a microprocessor or a digital signal processor (DSP)) from a computer-readable storage medium and executing the instructions by the processor), or by a combination of hardware and software.



FIG. 2A is a block diagram illustrating an embodiment of the Rx AFE 168 and Rx DSP 166 in further detail. The analog front end 168 receives an analog input signal vector 203. In one embodiment, the analog input signal vector 203 comprises four channels: (1) a horizontally polarized in-phase (HI) channel; (2) a horizontally polarized quadrature (HQ) channel; (3) a vertically polarized in-phase (VI) channel; and (4) a vertically polarized quadrature (VQ) channel. The analog front end 168 samples the analog input signal vector 203 to generate a digital signal vector 205. A digital signal processor 166 receives the digital signal vector 205 and performs various processing operations to generate an output signal vector 209 that is passed to the demodulator 164.


The physical characteristics of the transmitter 110 or receiver 160 (or both) may introduce skew between the various channels HI, HQ, VI, VQ in the digital signal vector 205 if left uncompensated. For example, skew between the HI and HQ channels or between the VI and VQ channels may introduce error in the quadrature phase relationships between the signals (i.e., the phase difference between the signals may vary from the expected 90° relationship). Furthermore, skew between the horizontal and vertical polarizations may be introduced that appear as a differential group delay (DGD) between the polarizations. The receiver 160 includes various components to compensate for this skew, thereby improving performance of the receiver 160.


In the AFE 168, a multi-channel analog-to-digital converter (ADC) 210 samples the analog input signal vector 203 to generate a digital signal vector 205. Each channel of the analog input signal 203 is sampled by the ADC 210 according to sampling clocks 207 which each corresponding to a different channel of the analog input signal 203 (e.g., sampling clocks CLKHI, CLKHQ, CLKVI, CLKVQ). By varying the relative phases of the sampling clocks 207, the different channels of the analog input signal 203 can be sampled with different relative timings, thereby compensating for skew.


A skew compensation block 220 generates the sampling clocks 207 for each channel based on an input clock signal 211. Based on a programmed level of skew compensation for each channel, the skew compensation block 211 adjusts the phase of the input clock signal 211 separately for each channel to generate each of the sampling clocks 207. For example, in one embodiment, the skew compensation block 220 comprises four programmable phase interpolators, one for each of the four channels. The phase interpolator for a given channel includes a programmable skew compensation register that can be programmed to introduce a particular amount of phase shift to the sampling clock for that channel. Based on the programmed value, the phase interpolator applies a phase shift to the input clock signal 211 to generate the sampling clock for the corresponding channel, thus compensating for the detected skew. Values for the skew compensation registers in the skew compensation block 220 may be programmed via a control signal 213 during a calibration phase described below. In one embodiment, this calibration phase is performed during an initial set up of the receiver at the beginning of its lifetime. Additionally, the receiver 160 may be recalibrated at later times (e.g., during a service call) by re-performing the calibration. Typically, the calibration is performed under ideal or near ideal laboratory conditions to avoid impairments effects introduced by a noisy channel. In alternative embodiments, however, calibration may also be performed periodically or continuously during normal operation of the receiver 160 in the field.


The DSP 166 receives the digital signal vector 205 and performs various processing operations to generate the digital output signal 209 representing the originally transmitted data. In one embodiment, the DSP 166 includes an equalizer 230 to equalize the channels of the digital signal vector 205.


In the DSP 166, the equalizer 230 compensates for channel impairments present in the digital signal vector 205 including, for example, chromatic dispersion, polarization mode dispersion, nonlinear optic effects, and polarization scrambling. In one embodiment, the equalizer 230 comprises a four channel feedforward adaptive equalizer that implements the following equation:










[





q
HI



(
n
)








q
HQ



(
n
)








q
VI



(
n
)








q
VQ



(
n
)





]

=




k
=
1

L




[





c
00



(
k
)






c
01



(
k
)






c
02



(
k
)






c
03



(
k
)








c
10



(
k
)






c
11



(
k
)






c
12



(
k
)






c
13



(
k
)








c
20



(
k
)






c
21



(
k
)






c
22



(
k
)






c
23



(
k
)








c
30



(
k
)






c
31



(
k
)






c
32



(
k
)






c
33



(
k
)





]



[





r
HI



(

n
-
k

)








r
HQ



(

n
-
k

)








r
VI



(

n
-
k

)








r
VQ



(

n
-
k

)





]







(
1
)








where rHI, rHQ, rVI, and rVQ are the inputs to the equalizer 230 representing the horizontally polarized in-phase channel (HI), the horizontally polarized quadrature channel (HQ), the vertically polarized in-phase channel (VI), and the vertically polarized quadrature channel respectively (VQ). qHI, qHQ, qVI, and qVQ are the outputs out of the equalizer 230. cab, (for a,bε[0, 1, 2, 3]) are filters (e.g., finite impulse response (FIR) filters), each having L taps (e.g., 16 taps). Here, the term “filter” is used in the mathematical sense to describe each of the individual vectors cab in equation (1). These vectors cab do not necessarily operate to filter signals independently of each other, but may instead be applied collectively in the equalizer 230 to achieve an overall filtering effect between an input signal and an output signal as described in equation (1).


During normal operation, the adaptive equalizer 230 dynamically adapts the taps of each of the filters cab based on the time-varying properties of the communication channel. The matrix C converges to values that compensate for the impairments and continuously changes as the impairment conditions change. For example, in one embodiment a least-mean-square (LMS) algorithm is used to adapt the taps of the filters cab to produce the least mean squares of an error signal. The equalizer 230 may alternatively use a different adaptive algorithm. As a result of the adaptive nature of the equalizer 230, the filters cab will adapt if the relative timing of an input channel changes with respect to the other channels. Thus, the equalizer coefficients can provide useful information about the operation of the transmitter 110, receiver 160 and channel 130, which can be used for skew calibration and channel diagnostics according to various techniques described below.


Other components of the DSP 166 are omitted for simplicity in the illustration. In various embodiments, the DSP 166 may furthermore include processing and filtering components such as, for example, a bulk chromatic dispersion compensation block, a polarization mode dispersion compensation block, a timing recovery block, etc.


In one embodiment, a separate processor 180 is coupled to the DSP 166 and AFE 168 includes a skew estimator 240 and a channel diagnostics block 270. For example, the processor 180 may be embodied on the same chip as the receiver 160 or in a physically separate device (e.g., on a host board). In one embodiment, the functions attributed to processor 180 described herein are carried out by executing program instructions stored to a computer-readable storage medium. Alternatively, the processor 180 can be implemented as an application specific integrated circuit or a field programmable gate array (FPGA)).


The skew estimator 240 is utilized during calibration of the receiver 160. For example, in one embodiment, the skew estimator 240 receives the equalizer coefficients from the equalizer 230 and generates the control signal 213 to program the skew compensation registers of the skew compensation block 220 during calibration. Further details regarding operation of the skew estimator are described below.


In another embodiment, the control signal 213 can be provided by a different external device. For example, in one embodiment, the equalizer coefficients are outputted external to the DSP 166 where they can be to manually determine calibration settings. The skew compensation values can then be programmed into the skew compensation block 220 via firmware, a field programmable gate array (FPGA), or erasable programmable read-only memory (EPROM) that controls the skew compensation block 220.


The channel diagnostics block 270 also receives the equalizer coefficients from the equalizer 230 and generates various types of channel information such as a differential group delay (DGD) estimate. In one embodiment, information from the Rx framer 163 is also used in performing the channel diagnostics computations. The channel diagnostics information is used to provide a channel diagnostics output 260 useful for calibration and reporting. Additionally, the DGD estimate could optionally be used by the skew estimator 240 to estimate H/V skew during the calibration phase.



FIG. 2B illustrates an alternative architecture in which the skew estimator 240 and channel diagnostics block 270 are instead embodied directly in the DSP 166 instead of in the separate processor 180.


Skew Compensation Based on Equalizer Coefficients


As described above, equalizer coefficients are used during calibration of the receiver 160 to estimate the skew between the channels and program the skew compensation block 220 to compensate for the estimated skew. It is generally desirable to perform calibration under ideal or near ideal operating conditions. Thus, in one embodiment, calibration is performed with the transmitter 110 and receiver 160 connected back-to-back (effectively bypassing the optical fiber). For example, in one embodiment, the back-to-back setup involves connecting the transmitter 110 to the receiver 160 using a channel 130 of negligible length. Furthermore, in one embodiment, certain features of the receiver 160 such as coarse carrier recovery may be bypassed during calibration. Additionally, it may be desirable to reduce the dynamic response of the equalizer 230 using available programmable options.


The calibration process is based on the adaptive operation of the equalizer 230 with respect to the incoming signal. Specifically, if the timing of rHQ changes with respect to the other inputs, the corresponding filters c01(k), c11(k), c21(k), c31(k) will adapt to reflect the change in timing. The inputs rHI, rHQ, rVI, and rVQ are not independent, but rather will maintain certain relationships when the channels are properly aligned. Because the equalizer 230 adapts to the channel data, the equalizer filters will maintain the channel relationships when the signals are aligned. Particularly, when the channels are properly aligned, the filters will reflect the appropriate in-phase and quadrature relationships between the input signals. Additionally, when the channels are properly aligned, the filters will maintain time reversal symmetry between the horizontally polarized inputs and the vertically polarized inputs. In an equalizer 230 having the characteristics of equation (1), the filter coefficients will have the following relationships when the HI and HQ channels are aligned: c11≈c00 and −c01≈c10. Furthermore, when the VI and VQ channels are aligned, the following relationships will be maintained: c33≈c22 and −c23≈c32.


When the channels are misaligned (e.g., due to skew between HI and HQ or between VI and VQ), the filter coefficients will adapt in response and will reflect the misalignment. In order to determine the amount of skew in the HQ channel relative to the HI channel, c11 is compared to c00 and −c01 is compared to c10. Similarly, to determine the amount of skew in the VQ channel relative to the VI channel, c33 is compared to c22 and −c23 is compared to c32.



FIG. 3 is a plot illustrating an example of tap values for filters c00 and c11 which may be used to compare skew between the HQ and HI channels. As can be seen, the tap values are misaligned, indicating a relative skew between the HI and HQ channels. By observing the relative positions of the taps corresponding to the filters c00 and c11, the skew estimator 240 can estimate the skew between the HI and HQ channels. The detected skew can then be provided to the skew compensation block 220 (via control signal 213) to compensate for the skew. Skew between the VI and VQ channels can be similarly estimated and compensated. A number of different methods can be used to compute a skew metric based on the tap coefficients, examples of which will be described below.


Correlation Method



FIG. 4 is a flowchart illustrating an embodiment of a process for calibrating skew compensation values according to a correlation method. In the correlation method, skew compensation values are tested over a range of values and optimal skew compensation values are then determined based on the calculated metrics. In one embodiment of the process, the skew compensation block 220 first sets 402 its skew compensation registers to initial values for testing. For example, the skew compensation block 220 programs the skew compensation values to introduce an appropriate amount of phase shift to the sampling clocks 207 that will compensate for the skew represented by the skew parameters τI, τQ, where τI refers to the skew parameter for the in phase channel (HI or VI) and τQ refers to the skew parameter for the quadrature channel (HQ or VQ).


The skew estimator 240 obtains 404 the coefficients of the relevant equalizer filters from the equalizer 230 while operating the receiver 160 with the skew compensation block 220 set based on the current skew parameters. For example, in one embodiment, a test data pattern is transmitted to the receiver 160 until the equalizer 230 converges (i.e., the filter coefficients adapt until they reach substantially stable values). The relevant filter coefficients are then read from the equalizer 230. To determine the skew between HI and HQ channels, coefficients of filters c11, c00, c01, and c10 are obtained. To determine the amount of skew between VQ and VI channels, coefficients of filters c33, c22, c23, and c32 are obtained. The skew estimator 240 computes 406 a skew metric between the in-phase and quadrature channels based on the obtained filter coefficients. For example, in one embodiment the skew metric is determined based on a correlation between the relevant filters using the following equation:

R(ab,cd)IQ)=Σn=1Lcab(n,τIccd(n,τQ);a,bε[0,1,2,3]  (2)

where R(ab,cd)I, τQ) represents a correlation metric between filters cab and ccd. For example, to determine skew between HI and HQ channels, R(00,11)1, τQ) and R(01,10) I, τQ) are computed, which represent the correlation between filters c00 and c11 and between filters c01 and c10 respectively. Then an overall correlation metric RHIHQ for the horizontally polarized channels can be determined by scaling each term by the energy of the corresponding filters:











R
HIHQ



(


τ
I

,

τ
Q


)


=


2


[



R

(

00
,
11

)




(


τ
I

,

τ
Q


)


-


R

(

10
,
01

)




(


τ
I

,

τ
Q


)



]





R

(

00
,
00

)




(


τ
I

,

τ
I


)


+


R

(

11
,
11

)




(


τ
Q

,

τ
Q


)


+


R

(

10
,
10

)




(


τ
I

,

τ
I


)


+


R

(

01
,
01

)




(


τ
Q

,

τ
Q


)








(
3
)







Similarly, to determine skew between VI and VQ channels, R(33,22) I, τQ) and R(23,32) I, τQ) are computed, which represent the correlation between filters c33 and c22 and between filters c23 and c32 respectively. Then an overall correlation metric RVIVQ for the vertically polarized channels can be determined as follows:











R
VIVQ



(


τ
I

,

τ
Q


)


=


2


[



R

(

33
,
22

)




(


τ
I

,

τ
Q


)


-


R

(

32
,
23

)




(


τ
I

,

τ
Q


)



]





R

(

33
,
33

)




(


τ
I

,

τ
I


)


+


R

(

22
,
22

)




(


τ
Q

,

τ
Q


)


+


R

(

32
,
32

)




(


τ
I

,

τ
I


)


+


R

(

23
,
23

)




(


τ
Q

,

τ
Q


)








(
4
)







In step 408, the skew estimator 240 determines whether there are additional skew compensation value to test. If there are additional skew compensation values to test, the skew compensation block 220 is programmed with new values and the process repeats from step 402. Once the full range of skew compensation values are tested, the optimal skew values are determined 410 based on the skew metrics (e.g., the metric indicating the highest correlation). The skew compensation block 220 is then configured with these optimal values for use during operation of the receiver 160. For example, in one embodiment, skew compensation registers associated with phase interpolators are configured to apply an appropriate amount of phase shift to the sampling clocks associated with each channel based on the determined skew.


Various strategies may be employed in selecting the range of skew compensation values for testing. For example, in one embodiment, the skew compensation registers for the in phase channel is set to the middle of its range (e.g., τI=0) and the skew compensation register for the quadrature channel is swept across a predefined testing range (e.g., ±2 unit intervals). Alternatively, the skew compensation register for the quadrature channel is fixed and the skew parameter for the in phase channel is swept across its range. In other embodiments, parametric sweeps may be performed to test different combinations of values for τI, τQ.


Center of Gravity Method


In another embodiment, a “center of gravity” method is used to determine the relative skew between the channels based on the equalizer coefficients. FIG. 4B is a flowchart illustrating an embodiment of a process for calibrating skew parameters according to the center of gravity method. Skew compensation values are first initialized 452 to initial values configured to compensate for skews τI, τQ. For example, in one embodiment, skew compensation values are initialized to the middle of the range to presume no skew in the signals (e.g., τ1, τQ=0). Once the equalizer 230 converges, the coefficients of the equalizer filters are then obtained 454 using the current skew compensation values. A center of gravity is then determined 456 based on the captured equalizer coefficients. The center of gravity represents the average tap number in which the highest amount of coefficient energy is concentrated (e.g., where the major peaks of the equalizer coefficients are located). The center of gravity therefore provides a good indication of the average tap position in which the equalizer coefficients are centered. A variety of different metrics may be used to compute the center of gravity. For example, in one embodiment, the centers of gravity for the horizontally polarized channels and the vertically polarized channels are computed as follows:










CGH
=





n
=
1

L




(
n
)



(





c
00



(
n
)




+




c
10



(
n
)





)







n
=
1

L



(





c
00



(
n
)




+




c
10



(
n
)





)










CGV
=





n
=
1

L




(
n
)



(





c
22



(
n
)




+




c
32



(
n
)





)







n
=
1

L



(





c
22



(
n
)




+




c
32



(
n
)





)








(

9

a

)








where CGH is the center of gravity of the horizontally polarized channels and CGV is the center of gravity for the vertically polarized channels. In another embodiment, additional coefficients may be considered in the center of gravity equations. For example, in another embodiment, the centers of gravity may be determined as follows:










CGH
=





n
=
1

L




(
n
)



(





c
00



(
n
)




+




c
10



(
n
)




+




c
11



(
n
)




+




c
01



(
n
)





)







n
=
1

L



(





c
00



(
n
)




+




c
10



(
n
)




+




c
11



(
n
)




+




c
01



(
n
)





)










CGV
=





n
=
1

L




(
n
)



(





c
22



(
n
)




+




c
32



(
n
)




+




c
33



(
n
)




+




c
23



(
n
)





)







n
=
1

L



(





c
22



(
n
)




+




c
32



(
n
)




+




c
33



(
n
)




+




c
23



(
n
)





)








(

9

b

)







In yet another alternative embodiment, the centers of gravity may be determined as follows:










CGH
=








n
=
1

L








(
n
)



(



(



c
00



(
n
)


+


c
11



(
n
)



)

2

+


(



c
01



(
n
)


-


c
10



(
n
)



)

2

+












(



c
02



(
n
)


+


c
13



(
n
)



)

2

+


(



c
03



(
n
)


-


c
12



(
n
)



)

2


)











n
=
1

L



(



(



c
00



(
n
)


+


c
11



(
n
)



)

2

+


(



c
01



(
n
)


-


c
10



(
n
)



)

2

+











(



c
02



(
n
)


+


c
13



(
n
)



)

2

+


(



c
03



(
n
)


-


c
12



(
n
)



)

2


)












CGV
=








n
=
1

L








(
n
)



(



(



c
20



(
n
)


+


c
31



(
n
)



)

2

+


(



c
21



(
n
)


-


c
30



(
n
)



)

2

+












(



c
22



(
n
)


+


c
33



(
n
)



)

2

+


(



c
23



(
n
)


-


c
32



(
n
)



)

2


)











n
=
1

L



(



(



c
20



(
n
)


+


c
31



(
n
)



)

2

+


(



c
21



(
n
)


-


c
30



(
n
)



)

2

+











(



c
22



(
n
)


+


c
33



(
n
)



)

2

+


(



c
23



(
n
)


-


c
32



(
n
)



)

2


)










(

9

c

)







In yet another alternative embodiment, the centers of gravity may be determined as follows:










CGH
=








n
=
1

L








(
n
)



(



(



c
00



(
n
)


+


c
11



(
n
)



)

2

+


(



c
01



(
n
)


-


c
10



(
n
)



)

2

+












(



c
20



(
n
)


+


c
31



(
n
)



)

2

+


(



c
21



(
n
)


-


c
30



(
n
)



)

2


)











n
=
1

L



(



(



c
00



(
n
)


+


c
11



(
n
)



)

2

+


(



c
01



(
n
)


-


c
10



(
n
)



)

2

+











(



c
20



(
n
)


+


c
31



(
n
)



)

2

+


(



c
21



(
n
)


-


c
30



(
n
)



)

2


)












CGV
=








n
=
1

L








(
n
)



(



(



c
22



(
n
)


+


c
33



(
n
)



)

2

+


(



c
23



(
n
)


-


c
32



(
n
)



)

2

+












(



c
02



(
n
)


+


c
13



(
n
)



)

2

+


(



c
03



(
n
)


-


c
12



(
n
)



)

2


)











n
=
1

L



(



(



c
22



(
n
)


+


c
33



(
n
)



)

2

+


(



c
23



(
n
)


-


c
32



(
n
)



)

2

+











(



c
02



(
n
)


+


c
13



(
n
)



)

2

+


(



c
03



(
n
)


-


c
12



(
n
)



)

2


)










(

9

d

)







A sweep of the skew compensation values then begins. For example, in one embodiment, the skew compensation values for the in-phase channels (HI and VI) are swept across a predefined testing range while the quadrature channels (HQ and VQ) remain constant at their centered value. Alternatively, the skew compensation values for the quadrature channels may be swept while the in-phase channels are held constant. To begin the sweep, the skew compensation value for the channel under calibration is set 458 to a first test value in a predefined testing range. The equalizer coefficients are then determined 460 once the equalizer 230 converges with the current skew compensation values. Error values for the current skew parameter are then calculated 512 as follows:











Δ






H
τ


=




n
=

round


(

CGH
-
x

)




round


(

CGH
+
x

)












HI
n

-

HQ
n













Δ






V
τ


=




n
=

round


(

CGV
-
x

)




round


(

CGV
+
x

)












VI
n

-

VQ
n










(
10
)








where x represents a tap range parameter (e.g., x=3) that defines a range around the tap closest to the center of gravity to be used in the error calculation, round ( ) is a function that returns the nearest integer of the argument, and where:

HIn=c00(n)−c10(n)
HQn=c11(n)+c01(n)
VIn=c22(n)−c32(n)
VQn=c33(n)+c23(n)  (11)


If in step 464, there are additional skew compensation values to test in the defined testing range, the next skew compensation value is applied and the process loops back to step 468.


Otherwise, once correlation metrics are determined for all skew compensation values in the desired testing range, the minimum error values ΔHmin and ΔVmin are determined 466 from all of the tested skew compensation values. The skew compensation values associated with the minimum error values are written to the skew compensation registers of the skew compensation block 220.


Group Delay Method


In another embodiment, the skew metric is determined by computing a difference in group delay between the relevant filters being compared. Let the discrete Fourier transform (DFT) of a filter be H(w)=A(ω)e−iΘ(ω). Where A(ω) is the magnitude of the frequency response and Θ(ω) is the phase. Then the group delay is defined as:










τ


(
ω
)


=




θ


(
ω
)





ω






(
12
)







For H polarization IQ skew, the group delay is computed as follows:












(
13
)








DFT


[


c
00



(
n
)


]


=



A
00



(
ω
)




exp


(


-
i








θ
00



(
ω
)



)




,






DFT


[


c
11



(
n
)


]


=



A
11



(
ω
)




exp


(


-
i








θ
11



(
ω
)



)




;








DFT


[


c
01



(
n
)


]


=



A
01



(
ω
)




exp


(


-
i








θ
01



(
ω
)



)




,






DFT


[


c
10



(
n
)


]


=



A
10



(
ω
)




exp


(


-
i








θ
10



(
ω
)



)




;








τ

(

00
,
11

)


=


(






θ
11



(
ω
)





ω


-





θ
00



(
ω
)





ω



)





ω
=
0




;






τ

(

10
,
01

)




(






θ
10



(
ω
)





ω


-





θ
01



(
ω
)





ω



)






ω
=
0











The group delays can be combined by to compute an overall skew value by scaling the group delays by the magnitude response at DC. In other words,

τHIHQ=([A002(0)+A112(0)]τ(00,11)+[A102(0)+A012(0)]τ(10,01))/[A002(0)+A112(0)+A102(0)+A012(0)]  (13b)


For V polarization IQ skew, the group delay is computed as follows:












(

14

a

)








DFT


[


c
00



(
n
)


]


=



A
22



(
ω
)




exp


(


-
i








θ
22



(
ω
)



)




,






DFT


[


c
33



(
n
)


]


=



A
22



(
ω
)




exp


(


-
i








θ
22



(
ω
)



)




;








DFT


[


c
01



(
n
)


]


=



A
23



(
ω
)




exp


(


-
i








θ
23



(
ω
)



)




,






DFT


[


c
32



(
n
)


]


=



A
32



(
ω
)




exp


(


-
i








θ
32



(
ω
)



)




;








τ

(

22
,
33

)


=


(






θ
22



(
ω
)





ω


-





θ
33



(
ω
)





ω



)





ω
=
0




;






τ

(

22
,
23

)




(






θ
32



(
ω
)





ω


-





θ
23



(
ω
)





ω



)






ω
=
0











The group delays can be combined to compute an overall skew value by scaling the group delays by the magnitude response at DC. In other words,

τVIVQ=([A222(0)+A332(0)]τ(22,33)+[A322(0)+A232(0)]τ(32,23))/[A222(0)+A332(0)+A322(0)+A232(0)]  (14b)


The skew compensation block 220 can then be set to compensate for the overall skew determined in Eqs. (13b) and (14b) above.


HV Skew Calibration


In another embodiment, a calibration process detects skew between the horizontally polarized channels and the vertically polarized channels (referred to herein as “HV skew”) and programs the skew compensation block 220 to compensate for the detected skew. To extract the HV skew information from the equalizer coefficients, IQ and time reversal symmetry relationships are applied. This relationship is embodied in the calculation of differential group delay (DGD) between the horizontally and vertically polarized channels. FIG. 5 illustrates an example embodiment for calibrating a receiver 160 to compensate for skew between the horizontal and vertical polarizations. For example, in one embodiment, once the skew compensation block 220 is configured with the appropriate offset I/Q offsets according to any of the techniques discussed above, the skew compensation values for the horizontal or vertical channels are then set 502 to a pair of compensation values that maintain the determined IQ offset. The equalizer coefficients are obtained 504 and the HV skew metric is computed 506 based on the DGD. Here, the DGD may be estimated according to the group delay method described above, or the DGD information may be obtained from the channel diagnostics block 270 (as indicated by the dashed arrow from the channel diagnostics block 270 to the skew estimator 240) using any of the techniques described below. If there are additional pairs of skew compensation values to test in step 508, the process loops back to step 502 and repeats for the next pair of values. Otherwise, the optimal values are selected 510 according to the same techniques described above (e.g., to minimize DGD).


The above described process may be used to generate skew metrics while varying the HI and HQ channels together across a testing range while maintaining the determined offset between HI and HQ. Alternatively, the above described process may be used to generate skew metrics while varying the VI and VQ channels together across a testing range while maintaining the determined offset between VI and VQ.


Channel Diagnostics Using Equalizer Coefficients


In one embodiment, the receiver 160 can also use the equalizer coefficients to perform channel diagnostics. In contrast to the calibration procedure discussed above, channel diagnostics is typically performed dynamically during real-time operation of the receiver 160 under field conditions in order to obtain real-time diagnostic information. Channel diagnostics estimate various time-varying characteristics of the incoming data signal, including, for example, the differential group delay (DGD) in the optical channel 130. In one embodiment, the obtained information can then be used to compensate for impairments introduced in the data channel. Additionally, the channel diagnostics information may be externally reported where it may be logged or analyzed to extract various types of performance information. The channel diagnostics process will produce the most accurate results when the receiver 160 is correctly calibrated to compensate for I/Q skew, which can be accomplished using any of the techniques mentioned above.


As with the skew compensation process described above, channel diagnostics information can be obtained based on the adaptive operation of the equalizer 230 with respect to the incoming signal. Eq. (1) can be rewritten as filtering electrical fields of the input signals to the equalizer 230 as follows:
















(
15
)






[










q
HI



(
n
)


+


iq
HQ



(
n
)










q
VI



(
n
)


+


iq
VQ



(
n
)






]

=







[










h
HHI



(
n
)


+


ih
HHQ



(
n
)








h
HVI



(
n
)


+


ih
HVQ



(
n
)










h
VHI



(
n
)


+


ih
VHQ



(
n
)








h
VVI



(
n
)


+


ih
VVQ



(
n
)






]





*













[










r
HI



(
n
)


+


ir
HQ



(
n
)










r
VI



(
n
)


+


ir
VQ



(
n
)






]






where:

hHHI=0.5*(c00+c11);
hHHQ=0.5*(c10−c02);
hHVI=0.5*(c02+c13);
hHVQ=0.5*(c12−c03);
hVHI=0.5*(c20+c31);
hVHQ=0.5*(c30−c21);
hVVI=0.5*(c22+c33); and
hVVQ=0.5*(c32−c23).  (16)


If Eqn. (15) is represented in the frequency domain, the operation will be matrix multiplication expressed as:

Q(ω)=H(ω)R(ω).  (17)

where ω is the angular frequency. If H(ω) is assumed to be a perfect inverse of the linear optical channel distortions, it is then possible to derive the channel parameters from H(ω):










H


(
ω
)


=


D


(
ω
)







n
=
1

N









U
n



(
ω
)





E
n

.








(
18
)








where D(ω) represents the frequency response of chromatic dispersion, and Un(ω) and En are matrices representing local birefringence and polarization dependent Loss (PD), respectively.


The chromatic dispersion (CD) portion of the channel distortions can be isolated from H(ω) by taking the determinant of H(ω):














det


(

H


(
ω
)


)


=





D
2



(
ω
)







n
=
1

N







det


(


U
n



(
ω
)


)



det


(

E
n

)






,






=





D
2



(
ω
)







n
=
1

N



k
n










(
19
)







Therefore, the amount of CD can be determined by quadratic fitting of the unwrapped phase of det(H(ω))1/2.


To isolate the effect of differential group delay (DGD), H(ω) is normalized by its determinant. The normalization will remove the effect of CD and minimize the effect of polarization-dependent loss (PDL):

T(ω)=H(ω)/det(H(ω)).  (20)


Where T(ω) represents the normalized frequency response of an ideal equalizer. The DGD can be derived from T(ω) using a frequency based method. In general, it is reasonable to assume that T(ω) for |ω−ω0|<B/(4π) can be approximated by:










T


(
ω
)


=




V

-
1




(

ω
0

)




[




exp


(

i







ωτ
n

/
2


)




0




0



exp


(


-
i






ω







τ
n

/
2


)





]




U


(

ω
0

)







(
21
)








where B is the symbol rate, ω0 is the offset between the signal and a local oscillator, and V and U are unitary transformation matrices. From Eqn. (19), DGD can be determined using the following equation:

τ(ωo)=√{square root over (det(dT(ω)/dω))}|ωo  (22)


The DGD varies with frequency. An accurate estimate of the DGD can be determined, in one embodiment, by averaging DGD over frequency. In one embodiment, DGD can be estimated by based on the fractional group delay of the frequency responses of each equalizer filter.


The equalizer can be seen as an approximation to an ideal fractional delay filter hu(n)=sin(π(n−μ))/(π(n−μ)) over the symbol rate. The DGD varies with frequency due to truncation of these ideal fractional delay filters. The approximation is the result of windowing the filter response. Its effect can be approximated by the convolution of the frequency response of the window function:

Hw(ω)=sin(ω(N/2))/(N sin(ω/2))  (23)

where N is number of taps.


The main lobe of the window function is 2/N. Given that the group delay and magnitude of frequency response of the ideal fractional delay filter are both constant in frequency, the variation is expected to have periods of 2/N. If group delay is averaged over the symbol rate, N/4 cycles of variations are expected. Assuming that the number of taps is a multiple of 4, the overall group delay can be accurately estimated by averaging the group delay over a range of frequencies:










τ
_

=


1

2

π






T
S


B








ω
0

-

2

π






T
s



B
/
2





ω
0

+

2

π






T
s



B
/
2







τ


(
ω
)









ω








(
24
)







where B is the symbol rate, Ts, is the sampling rate, and τ is the average group delay. τ is used by the channel diagnostics block 270 as the DGD estimation. The channel diagnostics information can be outputted externally to the receiver 160 (e.g., via a channel diagnostics output 260) to be used in various reporting and calibration procedures.



FIG. 6 illustrates an example embodiment of a process for detecting DGD using the principles described. The channel diagnostics block 270 obtains 602 equalizer coefficients representing the current state of the adaptive equalizer. The channel diagnostics block 270 then determines 604 a frequency response of the adaptive equalizer based on the equalizer coefficients. The channel diagnostics block 270 then determines 606 the average DGD based on the frequency response using the frequency averaging technique in Eq. (24) described above in which DGD is averaged over a range of operating frequencies.


In some implementations, the equalizer 230 itself may naturally add DGD in the receiver 160 based on the operating characteristics of the equalizer 230. This DGD is added after the data has been decoded by the receiver 160, so it does not directly affect performance and need not be compensated for by the skew compensation block 220. Nevertheless, it is desirable for the channel diagnostics information to accurately report the DGD added by the channel 130 and transmitter 110. Because this particular DGD is instead added by the receiver 160, it is desirable to mathematically remove this component from the DGD estimation included in the channel diagnostics output 260.


The DGD introduced by the equalizer 230 may include DGD that is an integer number of symbol periods. Blind adaptation of the equalizer 230 generally cannot resolve DGD that is an integer number of symbol period. Instead, information embedded in the Rx framer 163 can be used to detect this DGD. The DGD estimate can then be adjusted 608 based on the framer information. For example, in one embodiment, the Rx framer 163 monitors the H and V lane skew at the Rx framer 163 and provides this information to the channel diagnostics block 270. In one embodiment, this information can be obtained by reading a specific framer register after the DSP has converged.


The frequency response of the equalizer 230 can be represented as follows:









G
=


[




exp


(


i





ω





T

2

)




0




0



exp


(

-


i





ω





T

2


)





]



H


(
ω
)







(
25
)








where G is the frequency response of the equalizer, T is the equalizer induced skew that is an integer multiple of a symbol period determined by the Rx framer 163, and H is an inverse of the linear optical channel distortions. If the raw equalizer frequency response is normalized by its determinant, as described above, it is a reasonable to estimate the skews as being evenly distributed between H and V channels.


The channel diagnostics block 270 then applies an inverse matrix Ito G to adjust the DGD estimate, where:









I
=

[




exp


(

-


i





ω





T

2


)




0




0



exp


(


i





ω





T

2

)





]





(
26
)







The estimated DGD, as adjusted, is then outputted 612 in the channel diagnostics output 260.


Steps 602, 604, 606, 608 of FIG. 6 are generally performed periodically while the receiver 160 operates in order to provide real-time channel information. However, these steps may also be performed as part of the calibration procedure described above with the transmitter 110 and receiver 160 configured in the back-to-back configuration to remove channel impairments. Here, an optional step 610 is included, in which the channel diagnostics block 270 programs 608 the skew compensation values of the skew compensation block 220 to compensate for the detected DGD (e.g., by adjusting the phases of the sampling clocks of the horizontally polarized channels relative to the vertically polarized channels or vice versa).


In another embodiment, the channel diagnostics block 270 can use the equalizer coefficients to detect performance degradation resulting in high bit error rate and synchronization loss, and reset the DSP 166 in response. The DSP 166 applies various iterative algorithms that should converge on a solution during start up conditions. However, under certain channel conditions, these algorithms may not properly converge to best solution, thus resulting in high bit error rate and synchronization loss. By resetting the DSP 166 when such conditions are detected, the algorithms can start over under different channel conditions, and may thus converge to a new solution that provides improved performance.



FIG. 7A illustrates an embodiment of a process for handling performance degradation using channel information. The channel diagnostics block 270 obtains 702 centers of gravity based on the equalizer coefficients as described in equations (9a)-(9d) above. Here, the centers of gravity calculations may be performed in the channel diagnostics block 270, or may be obtained from the skew estimator 240. To achieve robust performance, the values of CGH and CGV should typically be within a target range centered at or near the midpoint of the taps (e.g., around 8.5 for a 16 tap filter cab(1) . . . cab(16). Thus, in one embodiment, the center of gravity is compared 704 to high and low threshold values which define a range around the midpoint. In different embodiments, this decision may be based on CGH only (independent of CGV), CGV only (independent of CGH), either CGH or CGV falling outside the range, or both CGH and CGV falling outside the range. In other embodiments, different weighting coefficients can be applied to the individual coefficients in the CGH and CGV definitions in equations (9a)-(9d) above for the purpose of this determination. If, the centers of gravity are not outside the thresholds (i.e., they are within the predetermined range), then the DSP 166 continues to operate normally and the process repeats 707. If, in step 706, the center of gravity falls outside the range, the receiver 160 resets 708 the DSP 166. The process then repeats 709 such that the centers of gravity are continuously monitored during operation.



FIG. 7B illustrates an alternative embodiment of a process for handling performance degradation using channel information. The process is similar to FIG. 7A described above, except that the process does not repeat 707 once centers of gravity within the predefined range are detected in step 706. Instead, if the centers of gravity are not outside the thresholds, the process ends 710 and the centers of gravity are no longer monitored.


Polarization Scrambling


In an alternative embodiment, an accurate estimate of DGD can instead be determined by computing an average DGD over a range of polarization states instead of averaging over a range of frequencies. FIG. 8 illustrates an alternative embodiment of an optical communication system 800 in which the optical front end 850 comprises a polarization scrambler 852, which receives the optical signal from the channel 130. The polarization scrambler 852 continuously changes the state of polarization of the optical signal over the Poincaré sphere, and passes the optical signal to the optical-to-electrical (O/E) converter 854. In one embodiment, the polarization scrambler 852 is configured to vary the polarization states such that the entire Poincaré sphere will be covered within a predetermined time period, thus representing all possible polarizations states. The O/E converter 854 converts the optical signal to an electrical signal, and passes the electrical signal to the receiver 160. Group delays τt are calculated at a single frequency ω0 for a range of time points t (which corresponds to different polarization orientations since the polarization scrambler 862 varies the polarization states over time). These group delays are then averaged over polarization orientations to calculate a mean group delay τ, which can be used as a DGD estimate for any of the applications discussed above.


In another embodiment, polarization scrambling takes place in the DSP 166 instead of in the optical front end 850. In this embodiment, a matrix rotator in the DSP 166 applies a matrix rotation R to the input vector:










R


(

θ
,
ϕ

)




[






r
HI



(
n
)






+


ir
HQ



(
n
)










r
VI



(
n
)






+


ir
VQ



(
n
)






]





(
27
)








where and R (θ, φ) is the rotation matrix given by










R


(

θ
,
ϕ

)


=


[







j


ϕ
2










0




0






-
j



ϕ
2






]



[





cos


(
ϕ
)










sin


(
ϕ
)







-

sin


(
ϕ
)






cos


(
ϕ
)





]






(
28
)








and where θ the polarization angle and φ is a random phase angle. More general forms of the rotation matrix may be used. Here, θ and φ are varied over time to achieve the different polarization angles. In one embodiment, θ and φ are varied such that all combinations of θ and φ are covered within a predefined time period. Multiple group delays τt (or τθ, φ) are calculated for different polarization orientations at a single frequency ω0, and averaged over polarization orientations to calculate a mean group delay τ, which can be used as a DGD estimate for any of the applications discussed above


In another embodiment, the matrix rotation R is applied to the equalizer coefficients outside the DSP 166, such as in processor 180, for the purpose of estimating the DGD.



FIG. 9 illustrates an example embodiment of a process for detecting and compensating for DGD in a receiver 160 using polarization scrambling. The channel diagnostics block 270 obtains 902 sets of equalizer coefficients representing the different states of the adaptive equalizer for a plurality of different polarization states of the input signal. This step may be accomplished by sampling the equalizer coefficients at several points in time as the polarization scrambler 852 or matrix rotator 250 changes the polarization states over time. The channel diagnostics block 270 then determines 904 different frequency responses of the adaptive equalizer based on the different sets of equalizer coefficients captured for the different polarization states. The channel diagnostics block 270 then determines 906 the average differential group delay using polarization averaging. For example, in one embodiment, the channel diagnostics block 270 averages the calculated DGD values τ(ω0) in Eq. (22) obtained for the different polarization states. The DGD estimate can then be adjusted 908 based on the framer information in the same manner described above. The estimated DGD is then outputted 912 in the channel diagnostics output 260.


Optionally, the process described above can also be performed during calibration of the receiver 160. Here, the optional step 910 is added in which the channel diagnostics block 270 adjusts 910 the skew compensation values of the skew compensation block 220 to compensate for the detected DGD (e.g., by adjusting the phases of the sampling clocks of the horizontally polarized channels relative to the vertically polarized channels or vice versa).


In one embodiment, where polarization scrambling is achieved in by matrix rotation, the receiver 160 includes a separate DSP path for channel estimation that is independent from the data path. An example architecture is illustrated in FIG. 10A with a data path 1020 and channel estimation path 1010. In various embodiments, the channel estimation path 1010 may be implemented within the DSP 166 or portions of the channel estimation path 1010 may be implemented in a separate processor 180 (e.g., the channel diagnostics block 270 may be external to the DSP 166). In this embodiment, the incoming digital input 205 passes through a data path 1020 including an equalizer 230 to produce a digital output 209 in the manner described above. Additional optional components of the data path 1020 are omitted for clarity of description. In a separate parallel channel estimation path 1010, a matrix rotator 1002 applies a matrix rotation to the digital input signal 205. A second equalizer 1004 equalizes the signal using adaptive equalization, and passes the coefficients to channel diagnostics block 270 which produces the channel diagnostics output 260. This embodiment beneficially bypasses the matrix rotator 1002 in the data path 1020, thus allowing the data to be processed without the dynamic rotation affecting the digital output 209.


Alternatively, in the embodiment of FIG. 10B, the matrix rotator 1002 may simply be applied prior to the equalizer 230 in the data path 1040. The channel estimation path 1030 includes the channel diagnostics block 270, which receives the equalizer coefficients directly from equalizer 230. Here, the digital output 209 is affected by the matrix rotation, but this embodiment has the benefit of having a simplified architecture relative to the embodiment of FIG. 10A.


Although the detailed description contains many specifics, these should not be construed as limiting the scope but merely as illustrating different examples and aspects of the described embodiments. It should be appreciated that the scope of the described embodiments includes other embodiments not discussed in detail above. For example, the functionality of the various components and the processes described above can be performed by hardware, firmware, software, and/or combinations thereof.


Various other modifications, changes and variations which will be apparent to those skilled in the art may be made in the arrangement, operation and details of the method and apparatus of the described embodiments disclosed herein without departing from the spirit and scope of the invention as defined in the appended claims. Therefore, the scope of the invention should be determined by the appended claims and their legal equivalents.

Claims
  • 1. A system comprising: an analog-to-digital converter to convert an analog signal vector to a digital signal vector, the analog signal vector having a plurality of channels, the analog-to-digital converter sampling each of the plurality of channels based on a corresponding sampling clock;a skew compensation block to generate the corresponding sampling clocks for each of the plurality of channels based on skew compensation values specifying an amount of skew compensation for each of the plurality of channels;an adaptive equalizer to equalize the digital signal vector, the adaptive equalizer to adaptively update coefficients based on characteristics of the digital signal vector and to generate an equalized signal vector; anda skew estimator to obtain the coefficients of the adaptive equalizer and determine an amount of skew between at least two of the plurality of channels from the coefficients of the adaptive equalizer, and to program the skew compensation block with the skew compensation values based on the determined amount of skew.
  • 2. The system of claim 1, wherein the skew compensation block comprises: a plurality of skew compensation registers corresponding to each of the plurality of channels, each skew compensation register storing a skew compensation value for its corresponding channel; anda plurality of phase interpolators corresponding to each of the plurality of channels, each phase interpolator applying a phase shift to an input clock based on the skew compensation value for its corresponding channel to generate the sampling clocks.
  • 3. The system of claim 1, wherein the skew estimator is configured to determine an amount of skew between a pair of channels based on a correlation metric representing a correlation between coefficients of pairs of filters of the adaptive equalizer.
  • 4. The system of claim 3, wherein the correlation metric is determined based on only a subset of coefficients in each of the filters, the subset of coefficients within a tap range centered at a center of gravity of the filters.
  • 5. The system of claim 1 wherein the adaptive equalizer is embodied in a digital signal processor, and wherein the skew estimator is embodied in an external processor separate from the digital signal processor, the external processor coupled to the digital signal processor to receive the equalizer coefficients.
  • 6. The system of claim 1 wherein the adaptive equalizer and the skew estimator are embodied in a digital signal processor.
  • 7. A method for calibrating a receiver to compensate for skew between channels, the method comprising: setting a first skew compensation value for a first channel to a first value for testing and a second skew compensation value for a second channel to a second skew value for testing, the first and second skew compensation values controlling an amount of skew compensation in their respective channels;obtaining coefficients of an adaptive equalizer when operating the receiver using the first and second skew compensation values;computing a skew metric approximating a skew between the first and second channel based on the obtained coefficients of the adaptive equalizer; andadjusting at least one of the first skew compensation value for the first channel and the second skew compensation value for the second channel based on the skew metric.
  • 8. The method of claim 7, wherein computing the skew metric comprises: determining a first correlation metric between a first pair of filters of the adaptive equalizer;determining a second correlation metric between a second pair of filters of the adaptive equalizer; anddetermining the skew metric based on the first and second correlation metrics.
  • 9. The method of claim 8, wherein determining the skew metric based on the first and second correlation metrics comprises: scaling the first and second correlation metrics by their respective energies; andsumming the scaled first and second correlation metrics.
  • 10. The method of claim 7, wherein computing the skew metric comprises: determining a center of gravity for a subset of filters of the adaptive equalizer;determining a tap range around the center of gravity;determining a correlation metric based on a subset of taps within the tap range for each of a plurality of filters of the adaptive equalizer; anddetermining the skew metric based on the correlation metric.
  • 11. The method of claim 10, further comprising: comparing a plurality of correlation metrics determined based on different skew compensation values.
  • 12. The method of claim 7, wherein the first channel and the second channel comprise an in-phase channel and a quadrature channel of a digital input vector, the method further comprising: setting skew compensation values for a first pair of similarly polarized channels to a first pair of values for testing, the first pair of values for testing maintaining an offset determined for the in-phase channel and the quadrature channel;obtaining coefficients of the adaptive equalizer when operating the receiver using the first pair of skew compensation values;computing a horizontal-vertical skew metric approximating a skew between horizontally and vertically polarized pairs of channels based on the obtained coefficients of the adaptive equalizer; andadjusting the first pair of skew compensation values based on the horizontal-vertical skew metric.
RELATED APPLICATIONS

This application claims the benefit of the following U.S. Provisional Applications: U.S. Provisional Patent Application Ser. No. 61/587,572 entitled “Automatic Skew Compensation Scheme Based on FFE Coefficients,” filed on Jan. 17, 2012 to Shih Cheng Wang; U.S. Provisional Application No. 61/677,460 entitled “Feed-Forward Equalizer Center-of-Gravity Monitoring in High-Speed Optical Communications Networks” filed on Jul. 30, 2012 to Mario R. Hueda, et al.; U.S. Provisional Patent Application Ser. No. 61/683,169 entitled “Automatic Receiver Deskew Procedure,” filed on Aug. 14, 2012 to Diego Crivelli, et al; U.S. Provisional Patent Application Ser. No. 61/704,490 entitled “Method Using Frequency Domain Averaging to Calculate Impairments in a Fiber-Optic Channel to Invert an FFE Matrix,” filed on Sep. 22, 2012 to Shih Cheng Wang, et al.; and U.S. Provisional Application No. 61/745,389 entitled “Method of Estimating Channel Performance Using Equalizer Tap Coefficients and Framer Information” filed on Dec. 21, 2012 to Shih Cheng Wang, et al. The contents of each of the above referenced applications are incorporated by reference herein in their entirety. This application is related to the following applications: U.S. Utility application Ser. No. 13/744,211 entitled “Channel Diagnostics Based on Equalizer Coefficients” filed on Jan. 17, 2013 to Shih Cheng Wang, et al.; and U.S. Utility application Ser. No. 13/744,235 entitled “Reset in a Receiver Using Center of Gravity of Equalizer Coefficients” filed on Jan. 17, 2013 to Mario Rafael Hueda, et al. The contents of each of the above referenced applications are incorporated by reference herein in their entirety.

US Referenced Citations (29)
Number Name Date Kind
4815103 Cupo et al. Mar 1989 A
5353312 Cupo et al. Oct 1994 A
5870372 Kuribayashi Feb 1999 A
6791995 Azenkot et al. Sep 2004 B1
7693214 Shida Apr 2010 B2
8077762 Agazzi Dec 2011 B2
8565621 Ibragimov et al. Oct 2013 B2
8731413 Dave et al. May 2014 B1
8873358 Saito et al. Oct 2014 B2
20070206963 Koc Sep 2007 A1
20080175590 Perkins et al. Jul 2008 A1
20090110046 Aziz et al. Apr 2009 A1
20100008413 Yamazaki et al. Jan 2010 A1
20110064421 Zhang et al. Mar 2011 A1
20110150506 Tanimura et al. Jun 2011 A1
20110229127 Sakamoto et al. Sep 2011 A1
20120189320 Zelensky et al. Jul 2012 A1
20120230676 Mo et al. Sep 2012 A1
20120257652 Malipatil et al. Oct 2012 A1
20120307025 Werner Lerche et al. Dec 2012 A1
20130051442 Cooper et al. Feb 2013 A1
20130084080 Shibutani Apr 2013 A1
20130209089 Harley et al. Aug 2013 A1
20130243127 Chmelar et al. Sep 2013 A1
20130251082 Abe, Junichi Sep 2013 A1
20130259490 Malouin et al. Oct 2013 A1
20130343490 Wertz et al. Dec 2013 A1
20140161470 Zelensky et al. Jun 2014 A1
20140254644 Gotman et al. Sep 2014 A1
Non-Patent Literature Citations (8)
Entry
El-Chammas, M. et al., “A 12-Gs/s 81-mW 5-bit Time-Interleaved Flash ADC With Background Timing Skew Calibration,” IEEE Journal Solid-State Circuits, Apr. 2011, pp. 838-847, vol. 46, No. 4.
Geyer, J.C. et al., “Optical Performance Monitoring using a 43Gb/s Realtime Coherent Receiver (Invited),” IEEE, 2009, pp. 93-94.
Geyer, J.C. et al., “Performance Monitoring Using Coherent Receivers,” IEEE, 2009, three pages.
Hauske, F. et al., “Optical Performance Monitoring in Digital Coherent Receivers,” Journal of Lightwave Technology, Aug. 15, 2009, pp. 3623-3631, vol. 27, No. 16.
Leven, A. et al., “Real-Time Implementation of Digital Signal Processing for Coherent Optical Digital Communication Systems,” IEEE Journal of Selected Topics in Quantum Electronics, Sep./Oct. 2010, pp. 1227-1234, vol. 16, No. 5.
Nelson, L. et al., “Performance of 46-Gbps Dual-Polarization QPSK Transceiver With Real-Time Coherent Equalization Over High PMD Fiber,” J. Lightwave Tech., Feb. 2009, pp. 158-167, vol. 27, No. 3.
Viterbi, A. et al., “Nonlinear Estimation of PSK-Modulated Carrier Phase with Application to Burst Digital Transmission,” IEEE Transactions on Information Theory, Jul. 1983, pp. 543-551, vol. 29, No. 4.
Greshishchev, Y. et al., “A 40GS/s 6b ADC in 65nm CMOS,” ISSCC Dig. IEEE International Solid-State Circuits Conference, 2010, pp. 390-392.
Provisional Applications (5)
Number Date Country
61587572 Jan 2012 US
61677460 Jul 2012 US
61683169 Aug 2012 US
61704490 Sep 2012 US
61745389 Dec 2012 US