1. Field of the Invention
Embodiments of the invention relate to the field of communication, and more specifically, to in-phase and quadrature imbalance calibration.
2. Description of Related Art
Radio frequency (RF) receivers or transmitters employing direct conversion architectures generate in-phase and quadrature (I-Q) analog signals. These signals usually have distortions which limit demodulator or modulator performance. These distortions, called quadrature errors, are caused by the gain and phase imbalances between the I-Q signal components. Imbalance in I-Q signals may induce an image frequency and direct current (DC) offset which interfere with the demodulation or modulation process. To correct the I-Q imbalance, it is necessary to calibrate the communication subsystem. Existing calibration methods typically utilize iterative approaches. These techniques correct the phase error, then the gain error, repeatedly in iterative sweeps.
Existing calibration techniques have a number of disadvantages. First, the iterative approach requires multiple processing passes, resulting in long processing time. This long processing time may cause a communication receiver or transmitter to be out-of-service. For communications services requiring constant bit rates, such as telephony or real-time video, the out-of-service interruption may cause undesirable performance. Second, the iterative nature of the technique is not accurate and achieves poor results, leading to degraded performance.
Embodiments of the invention may best be understood by referring to the following description and accompanying drawings that are used to illustrate embodiments of the invention. In the drawings:
An embodiment of the present invention includes a technique to calibrate receiver and transmitter in a communication system. N digitized samples I(n) and Q(n) are stored. The N digitized samples represent in-phase and quadrature (I-Q) components, respectively, of a down-converted signal from a receiver. The I-Q components are generated from a quadrature modulator or demodulator having I-Q imbalance. Phase and gain adjustment constants are computed from the N digitized samples to compensate for the I-Q imbalance using a closed form solution.
Another embodiment of the present invention includes a technique to calibrate a transceiver in a communication system without using a calibrated reference receiver. A first test signal at a first frequency is injected to a transmitter having a quadrature modulator with I-Q imbalance. The quadrature modulator has a carrier frequency. The transmitter generates a transmitter signal. The transmitter signal is detected to generate a composite signal having the first test signal and a second test signal at a second frequency twice the first frequency. The composite signal is digitized. I-Q direct current (DC) offset, phase, and gain corrections are computed from the digitized composite signal to correct the I-Q imbalance using a closed form solution.
In the following description, numerous specific details are set forth. However, it is understood that embodiments of the invention may be practiced without these specific details. In other instances, well-known circuits, structures, and techniques have not been shown in order not to obscure the understanding of this description.
One embodiment of the invention may be described as a process which is usually depicted as a flowchart, a flow diagram, a structure diagram, or a block diagram. Although a flowchart may describe the operations as a sequential process, many of the operations can be performed in parallel or concurrently. In addition, the order of the operations may be re-arranged. A process is terminated when its operations are completed. A process may correspond to a method, a program, a procedure, a method of manufacturing or fabrication, etc.
Embodiments of the invention include a technique to calibrate a receiver or a transmitter in a communication system to compensate for I-Q imbalances in the quadrature demodulator or modulator circuit. The calibration is performed in the digital domain using a closed-form solution to provide fast calibration. The closed-form solution includes application of formulas or equations to compute the adjustment constants or the imbalance corrections. After calibration, the adjustment constants or imbalance corrections may be applied in the compensator circuit to compensate for the I-Q imbalance. The compensation is performed in the digital domain.
In one embodiment, the technique is used to calibrate a receiver. An input signal is injected into the input of the RF receiver. The signal goes through the mixing process in the quadrature demodulator circuit to be down-converted to base-band signal. The base-band signal is then converted to digital samples. The digitized samples are stored in memory to be processed by a processing unit. The processing unit computes the adjustment constants from the stored digitized samples using a closed-form solution. The computation of the adjustment constants therefore takes place in one single pass, involving direct calculations of the constants using formulas. Accordingly, the calibration is fast, efficient, and accurate.
The same procedure may be used to calibrate a transmitter. In this scheme, a calibrated reference receiver is needed to provide the receiver path for the signal. A reference test signal is passed through the transmitter quadrature modulator that has the I-Q imbalance that needs to be compensated. The generated transmitted signal is looped back to the calibrated reference receiver. Since the calibrated reference receiver introduces no distortions, the distortions in the received signal are caused by the transmitter quadrature modulator. The same procedure to compute the phase and gain adjustment constants for the receiver calibration is used.
After the adjustment constants are computed, they may be applied to the receiver or the transmitter to compensate for the I-Q imbalance in the quadrature demodulator or modulator. For a receiver, these constants are applied after the down-conversion by the RF quadrature demodulator on the I-Q signals. For a transmitter, these constants are applied before the up-conversion by the RF quadrature modulator on the I-Q signals to pre-compensate for the I-Q imbalance. In both cases, the compensation is performed in the digital domain.
An alternative method to calibrate a transmitter without using a calibrated reference receiver. This technique utilizes a transmitter power detector built into the RF transceiver circuit. A first test signal is generated to go through the quadrature modulator in the transmitter. The transmitter signal passes through a detector. The detector includes a squarer and a low pass filter. The low pass filter removes the carrier frequency of the quadrature modulator. The detector generates a composite signal having the first signal and a second signal at a second frequency twice the first frequency. The composite signal is then digitized by an analog and digital converter. The digitized samples of the composite signal are stored. A processing unit computes I-Q DC offset, phase, and gain corrections from the digitized composite signal using a closed form solution. The I-Q DC offset, phase, and gain corrections are used to pre-compensate the I-Q balance in a pre-compensation circuit before the quadrature modulator circuit. The computation of the corrections therefore takes place in one single pass, involving direct calculations of the corrections using formulas. Accordingly, the calibration is fast, efficient, and accurate.
The input signal is received from an RF antenna. The BPF 110 removes unwanted frequencies from the frequency band of interest. The LNA 115 amplifies the filtered signal with proper gain.
The quadrature demodulator 120 down converts the received signal to base-band signal. The quadrature demodulator 120 includes a local oscillator 125, a splitter 127, two mixers 130 and 135, and two buffers 140 and 145. The local oscillator 125 generates a carrier waveform having a carrier frequency. The splitter 127 splits the carrier waveform into two waveforms that are phase shifted by 90°. The mixers 130 and 135 mix, or multiply, the received signal with the phase shifted signals to provide two channels: the in-phase (I) channel and the quadrature (Q) channel. The two buffers 140 and 145 buffer the resulting I-Q components of the quadrature demodulated signal. The quadrature demodulator 120 may have I-Q imbalance that cause signal distortions.
The I-Q ADCs 150 and 155 convert the respective I-Q components from the quadrature demodulator 120 into digital data. The I-Q compensator 160 compensates the I-Q imbalance in the quadrature demodulator 120 to provide corrected I-Q components. The I-Q compensator 160 uses the adjustment constants as computed by the processing unit 190 to perform the compensation. During calibration, the I-Q compensator 160 may be in calibration mode that passes the digitized I-Q components without change. After calibration, the I-Q compensator 160 may be loaded with the adjustment constants and activated to perform the compensation function. The digital demodulator 170 applies digital demodulation to the corrected I-Q components according to the receiver functions.
The memory 180 stores N digitized I-Q samples for processing. It may be any storage device (e.g., fast static random access memory) that can store the digitized I-Q samples at the real-time rate. The size of the memory is selected according to the desired number of digitized samples to be stored.
The processing unit 190 includes a programmable processor that executes programs or instructions to compute the adjustment constants to compensate for the I-Q imbalance. The processing unit 190 provides the adjustment constants to the I-Q compensator 160.
The adjustment constants a11, a12, a21, and a22 10, 15, 20, and 25 are the gain and phase adjustment constants or corrections to compensate for the I-Q imbalance as computed in a closed-form solution by the processing unit 190 during a calibration procedure. They may be stored in storage elements such as registers, buffer memory, or any other storage elements including hardwired data. They are components of the matrix A as computed by the processing unit 190 described in the process 730 shown in
The adder 162 adds a first product P1 to a second product P2 to produce the I component in the communication path of the receiver subsystem 100. As described above, the communication path has a quadrature demodulator to translate frequency of the received signal. The quadrature demodulator has I-Q imbalance or distortion that may be compensated or corrected by the gain and phase adjustment constants a11, a12, a21, and a22. The adder 163 adds a third product P3 to a fourth product P4 to produce the Q component in the communication path.
The multipliers 164 and 166 multiply the input I′ and Q′ components in the communication path with the adjustment constants a11 and a12, 10 and 15, respectively, to produce the first and second products P1 and P2, respectively, to the adder 162. The multipliers 165 and 167 multiply the input Q′ and I′ components in the communication path with the adjustment constants a22 and a21, 20 and 25, respectively, to produce the third and fourth products P3 and P4, respectively.
The digital modulator 210 performs digital modulation according to the transmitter function. This may include various encoding functions such as error coding, etc. The I-Q compensator 220 applies the adjustment constants or imbalance corrections to pre-compensate for the I-Q imbalance or distortions in the quadrature modulator 250. The I-Q DACs 230 and 235 convert the I-Q digital data to analog base-band signals. The LPFs 240 and 245 low pass filter the analog base-band signals on the respective I-Q channels to remove unwanted frequencies.
The quadrature modulator 250 up-converts the base-band signals to the desired frequency. The quadrature modulator 250 includes a local oscillator 255, a splitter 260, two mixers 270 and 275, and a combiner 280. The local oscillator 255 generates a carrier waveform having a carrier frequency. The splitter 260 splits the carrier waveform into two waveforms that are phase shifted by 90°. The mixers 270 and 275 mix, or multiply, the base-band signals with the phase shifted signals to provide I-Q components of the RF signal to be transmitted. The quadrature modulator 250 may have I-Q imbalance that cause signal distortions. The combiner 280 combines, or adds, the I-Q components of the RF signal into a composite RF output signal.
The PA 285 amplifies the composite RF signal for transmission to an RF antenna. The calibrated reference receiver 290 is a receiver subsystem that has been calibrated to compensate for I-Q imbalance in its quadrature demodulator. It is similar to the receiver subsystem 100. The memory 292 and the processing unit 295 are similar to the memory 180 and the processing unit 190, respectively, shown in
The adjustment constants a11, a12, a21, and a22 10, 15, 20, and 25 are the gain and phase adjustment constants or corrections to compensate for the I-Q imbalance as computed in a closed-form solution by the processing unit 295 during a calibration procedure. These are similar to the constants shown in
The adder 222 adds a first product P1 to a second product P2 to produce the I′ component in the communication path of the transmitter subsystem 200. As described above, the communication path has a quadrature modulator to translate frequency of the base-band signal. The quadrature modulator has I-Q imbalance or distortion that may be pre-compensated or corrected by the gain and phase adjustment constants a11, a12, a21, and a22. The adder 223 adds a third product P3 to a fourth product P4 to produce the Q′ component in the communication path.
The multipliers 224 and 226 multiply the input I and Q components in the communication path with the adjustment constants a11 and a12, 10 and 15, respectively, to produce the first and second products P1 and P2, respectively, to the adder 222. The multipliers 225 and 227 multiply the input Q and I components in the communication path with the adjustment constants a22 and a21, 20 and 25, respectively, to produce the third and fourth products P3 and P4, respectively.
The calibration of the transmitter subsystem 200 is performed using the calibrated reference receiver 290. When such a receiver is not available, an alternate calibration technique may be employed. This technique may be illustrated in
The signal generator 310 generates a test signal at a pre-determined frequency. The test signal becomes the I component, i.e., I1 in the communication path. The phase shifter 315 phase shifts the test signal 90° to provide the Q component, e.g., Q1. The signal generator 310 and the phase shifter 315 may be used to emulate a digital modulator normally used in a transmitter. The signal generator 310 therefore may be implemented as a digital signal generator that generates digital data. The test signal may be a single-tone signal that has a single frequency. In other words, it may be generated as a sinusoidal waveform at a pre-determined frequency.
The pre-compensation circuit 320 receives the I-Q components I1 and Q1 of the modulator as emulated by the signal generator 310 and the phase shifter 315 to generate pre-compensated I-Q components I2 and Q2 to the I-Q DACs 330 and 335, respectively. The pre-compensation circuit 320 uses compensation constants to compensate for the I-Q imbalance in the quadrature modulator 355. The compensation constants are computed using a closed-form solution in a calibration procedure.
The I-Q DAC2330 and 335 convert the respective I-Q digital data I2 and Q2 from the pre-compensation circuit 320 to analog I-Q base-band signals I3 and Q3, respectively. The error circuit 350 models the I-Q imbalance in terms of DC offset, gain error, and phase error.
The quadrature modulator 355 up-converts the base-band signals to the desired frequency. The quadrature modulator 355 includes a local oscillator 340, a phase shifter 345, two mixers 360 and 365, and a combiner 370. The local oscillator 340 generates a carrier waveform having a carrier frequency. The original carrier waveform corresponds to the I component. The phase shifter 345 phase shifts the carrier waveform by 90° to correspond to the Q component. The mixers 360 and 365 mix, or multiply, the base-band signals as passed by the error circuit 350 with the original and the phase shifted signals to provide I-Q components of the RF signal to be transmitted. The quadrature modulator 355 may have I-Q imbalance that cause signal distortions. The combiner 370 combines, or adds, the I-Q components of the RF signal into a transmitter signal.
During calibration, the transmitter signal from the quadrature modulator 355 is fed to the detector 380. The detector 380 generates a composite signal having the first signal as the test signal first and second frequencies from the transmitter signal, the second frequency being twice the first frequency. The detector 380 includes an analog multiplier 382 and a low-pass filter (LPF) 384. The analog multiplier 382 multiplies the transmitter signal to itself, or squares the transmitter. If the transmitter signal contains the test signal which is a single-tone sinusoidal signal, the squaring introduces an additional second test signal having a second frequency which is twice the frequency of the test signal. The LPF 384 has a corner frequency at approximately above the second frequency. Since the first frequency is much less than the carrier frequency, the second frequency is also much less than the carrier frequency. The LPF 384 therefore removes the carrier frequency while passing the first and second signals. The magnitudes and phases of the first and second signals provide a relationship with the DC offset, phase and gain errors due to the I-Q imbalance. The ADC 390 converts the analog signal from the detector to digital data to provide digitized samples of the composite signal. The digitized samples are used to compute the compensation constants.
The memory 392 and the processing unit 395 are similar to the memory 292 and the processing unit 295, respectively, shown in
The I-Q gain imbalance circuit 410 generates I-Q gain pre-compensated components. It includes I-Q gain multipliers 420 and 425 to multiply the modulator I-Q components I1 and Q1 with I-Q gain compensation constants 430 and 435 to produce the I-Q gain pre-compensated components. The I-Q gain compensation constants 430 and 435 are GAIN/2 and −GAIN/2, respectively. The value of GAIN is the ΔGc as shown in
The I-Q phase imbalance circuit 440 generates I-Q gain and phase pre-compensated components from the I-Q gain pre-compensated components. It includes multipliers 442, 446, 452, and 456, and two adders 460 and 465.
The multipliers 442 and 456 multiply the I-Q gain pre-compensated components with I-Q phase compensation constants 444 and 464, respectively, to produce first and second products, respectively. The I-Q phase compensation constants 444 and 464 are cos θ and sin θ, respectively. The value of the phase θ is the Δφc as shown in
The multipliers 452 and 446 multiply the Q-I components with the Q-I phase compensation constants 454 and 462, respectively, to produce the third and fourth products, respectively. The Q-I phase compensation constants 454 and 462 are cos θ and sin θ, respectively. The value of the phase θ is the Δφc as shown in
The adder 460 adds the first product to the second product to produce the I gain and phase pre-compensated component. The adder 465 adds the third product to the fourth product to produce the Q gain and phase pre-compensated component.
The DC offset circuit 470 generated the imbalance pre-compensated I-Q components. It includes I-Q DC offset adders 480 and 490 to add the I-Q gain and phase pre-compensated components to I-Q DC offset compensation constants 485 and 495, respectively, to produce the pre-compensated I-Q components. The I-Q DC offset compensation constants 485 and 495 are VIc and VQc, respectively. The VIc and VQc are the VIc and VQc, respectively, shown in
The adders subtract I-Q DC offset compensation constants 515 and 525 from corresponding outputs of the I-Q DACs 330 and 335 to generates first and second differences, respectively. The I-Q DC offset compensation constants 515 and 525 are VIc and VQc, respectively.
The multipliers 530 and 540 multiply the first and second differences with negatives of I-Q gain compensation constants 535 and 545, respectively, to produce I-Q inputs I4 and Q4 to the mixer circuit in the quadrature modulator 355. The I-Q gain compensation constants 535 and 545 are GAIN/2 and −GAIN/2, respectively. The I-Q delay elements 550 and 560 provide I-Q phase errors to the I-Q carrier wave components from the oscillator 340.
Upon START, the process 600 determines if the calibration is for a receiver or a transmitter. If the calibration is for a receiver, the process 600 injects a single un-modulated signal into the receiver (Block 610). The receiver has a quadrature demodulator to down convert the signal to base-band signal. The quadrature demodulator has the I-Q imbalance that may need to be compensated or adjusted. Next, the process 600 stores N digitized samples I(n) and Q(n), where n is the sample index, representing the I-Q components, respectively, of the down-converted signal from the receiver (Block 620). The I-Q components are generated from the quadrature demodulator.
Then, the process 600 computes phase and gain adjustment constants from the N digitized samples to compensate for the I-Q imbalance using a closed form solution (Block 630). The process 630 is explained in
If the calibration is for a transmitter, the process 600 generates a signal from a modulator in the transmitter (Block 640). The transmitter has the quadrature modulator on a transmitter path with the I-Q imbalance. Next, the process 600 loops the signal back into a receiver path having a calibrated reference receiver (Block 650). The calibrated reference receiver has a receiver mixer to down convert the signal to base-band signal. The receiver mixer has been calibrated such that it does not have I-Q imbalance. The I-Q imbalance embedded in the signal, therefore, is from the transmitter that is being calibrated. The process 600 then proceeds to block 620 to compute the adjustment constants for the transmitter using the closed-form solution in the same manner as the solution for receiver calibration except that the adjustment constants are now used for the transmitter.
Upon START, the process 630 computes the in-phase average power PI,avg, the quadrature average power PQ,avg, and the I-Q correlation RIQ from the N digitized samples I(n) and Q(n) (Block 710). Next, the process 630 estimates the gain difference Δg and the phase difference Δφ using the in-phase average power PI,avg, the quadrature average power PQ,avg, and the I-Q correlation RIQ (Block 720). Then, the process 630 computes a matrix
using the gain difference Δg and the phase difference Δφ (Block 730). The matrix A has components a11, a12, a21, and a22 being the phase and gain adjustment constants. The process 630 is then terminated.
Upon START, the process 710 computes the in-phase average power PI,avg (Block 810), the quadrature average power PQ,avg (Block 820), and the I-Q correlation RIQ (Block 830) according to the following equations:
The process 710 is then terminated.
Upon START, the process 720 estimates the gain difference Δg as follows:
The derivation of equation (4) is given later in the following. Next, the process 720 estimates the phase difference Δφ as follows:
The derivation of equation (5) is given later in the following. The process 720 is then terminated.
Upon START, the process 730 computes the gain matrix G as follows using the gain difference Δg as computed in equation (4).
Next, the process 730 computes the phase matrix P as follows using the phase difference Δφ computed in equation (5).
Then, the process 730 computes the product matrix M by multiplying matrices G and P as follows:
M=GP (8)
Next, the process 730 computes matrix A as the inverse of the product matrix M computed in equation (8) as follows:
A=M−1 (9)
The matrix
thus contains the components a11, a12, a21, and a22 which are the phase and gain adjustment constants or imbalance corrections to be used in the receiver compensator 160 (
The process 730 may also optionally update the matrix A by repeating the above computation and updating matrix A as follows:
B(n)=A·B(n−1) (10)
where B(0)=I, I is the identity matrix.
The process 730 is then terminated.
Equations (4) and (5) provide expressions for the computations of the phase and gain adjustments constants. These expressions may be derived in the following.
The I-Q imbalance is modeled using the following equation
Derivation of the Gain Adjustment Constant Δg as Shown in Equation (4).
Assuming Δφ=0, IQ imbalance is as follows,
With these equations, the derivation is as follow,
From equation (16), Δg may be obtained:
Derivation of the Phase Adjustment Constant Δφ as Shown in Equation (5):
Assuming Δg=0 and Δφ<<1, IQ imbalance is as follows:
RIQ may be expressed as:
Upon START, the process 900 injects a first test signal at a first frequency to a transmitter having a quadrature modulator with I-Q imbalance (Block 910). The quadrature modulator has a carrier frequency. The transmitter generates transmitter signal. Next, the process 900 detects the transmitter signal to generate a composite signal having the first test signal and a second test signal at a second frequency which is twice the first frequency (Block 920).
Then, the process 900 digitizes the composite signal (Block 930). This may be performed by a suitable ADC with a proper sampling frequency fs. Next, the process 900 computes the I-Q DC offset, phase, and gain corrections, VIc, VQc, Δφc, and ΔGc, from digitized composite signal to correct I-Q imbalance using closed form solution (Block 940). The process 900 is then terminated.
Upon START, the process 920 squares the transmitter signal using an analog multiplier (Block 1010). The squaring effectively introduces a second signal or tone appearing at twice the frequency of the first tone in the first test signal. Next, the process 920 filters the squared signal with a low-pass filter having a corner frequency at approximately the second frequency (Block 1015). The low-pass filter removes the carrier frequency and passes first and second test signals. The process 920 is then terminated.
Upon START, the process 940 computes a path delay D from the detecting and the digitizing, i.e., from the detector 380 to the ADC 390, (Block 1020). The path delay D is measured in degrees. This may be performed by setting the Q channel input to zero, i.e., setting the input Q1, after the phase shifter 315 in
Next, the process 940 computes the first and second magnitudes, M1 and M2, of the first and second test signals, respectively (Block 1025). Then, the process 940 computes the first and second phases, Φ1 and Φ2, of the first and second test signals, respectively (Block 1030). Next, the process 940 computes the I DC offset correction VIc=M1 cos((Φ1−D/2)π/180) (Block 1035). Then, the process 940 computes the Q DC offset correction VQc=−M1 sin((Φ−D/2)π/180) (Block 1040). Next, the process 940 computes the phase correction Δφc=−M2 cos((Φ2−D/2)π/180) (Block 1045). Then, the process 940 computes the gain correction ΔGc=−2 M2 sin((Φ2−D/2)π/180) (180/π) (Block 1050). The process 940 is then terminated.
The computations of the I-Q DC offset, phase, and gain corrections, VIc, VQc, Δφc, and ΔGc are based on the transmitter and error circuit model as shown in
The equations for the various quantities in the transmitter shown in
i=cos((2πfm/fs) (Δt−ΔS)) (22a)
q=sin((2πfm/fs) (Δt−ΔS)) (22b)
I=(i cos((Δφc π/180)./2)−q sin((Δφc π/180)/2)) ((1+ΔGc/2)/(1−ΔGc/2)) (23a)
Q=(q cos((Δφc π/180)/2)−i sin((Δφc π/180)/2)) ((1−ΔGc/2)/(1+ΔGc/2)) (23b)
V=(I−VIc+VIp) (1−ΔGp) cos((2πfc/fs) (Δt−ΔS)+(Δφp π/180)/2)−(Q−VQc+VQp) (1+ΔGp) sin((2πfc/fs) (Δt−ΔS)−(Δφp π/180)/2) (24)
The equations for the corrections are:
VIc=M1 cos((Φ1−D/2)π/180) (25)
VQc=−M1 sin((Φ1−D/2)π/180) (26)
Δφc=−M2 cos((Φ2−D/2)π/180) (27)
ΔGc=−2 M2 sin((Φ2−D/2)π/180) (180/π) (28)
where M1: Magnitude of the first test signal, or tone, in volts
The processor unit 1110 represents a central processing unit of any type of architecture, such as processors using hyper threading, security, network, digital media technologies, single-core processors, multi-core processors, embedded processors, mobile processors, micro-controllers, digital signal processors, superscalar computers, vector processors, single instruction multiple data (SIMD) computers, complex instruction set computers (CISC), reduced instruction set computers (RISC), very long instruction word (VLIW), or hybrid architecture.
The MC 1120 provides control and configuration of memory and input/output devices such as the main memory 1130 and the IOC 1140. The MC 1120 may be integrated into a chipset that integrates multiple functionalities such as graphics, media, isolated execution mode, host-to-peripheral bus interface, memory control, power management, etc. The MC 1120 or the memory controller functionality in the MCH 1120 may be integrated in the processor unit 1110. In some embodiments, the memory controller, either internal or external to the processor unit 1110, may work for all cores or processors in the processor unit 1110. In other embodiments, it may include different portions that may work separately for different cores or processors in the processor unit 1110.
The main memory 1130 stores system code and data. The main memory 1130 is typically implemented with dynamic random access memory (DRAM), static random access memory (SRAM), or any other types of memories including those that do not need to be refreshed. The main memory 1130 may include multiple channels of memory devices such as DRAMs. The main memory 1130 may include a calibration module 1135. The calibration module 1135 includes program instructions and data to perform the calibration functions as described above. The calibration module 1135 may include or interface to a suitable mathematical or signal processing software packages (e.g., MathLab) to perform computations of the adjustment constants or corrections.
The graphics processor 1140 is any processor that provides graphics functionalities. The graphics processor 1140 may also be integrated into the MC 1120 to form a Graphics and Memory Controller (GMC). The graphics processor 1140 may be a graphics card such as the Graphics Performance Accelerator (AGP) card, interfaced to the MC 1120 via a graphics port such as the Accelerated Graphics Port (AGP) or a peripheral component interconnect (PCI) Express interconnect. The graphics processor 1140 provides interface to an external display device such as standard progressive scan monitor, television (TV)-out device, and Transition Minimized Differential Signaling (TMDS) controller.
The IOC 1150 has a number of functionalities that are designed to support I/O functions. The IOC 1150 may also be integrated into a chipset together or separate from the MC 1120 to perform I/O functions. The IOC 1150 may include a number of interface and I/O functions such as peripheral component interconnect (PCI) bus interface, processor interface, interrupt controller, direct memory access (DMA) controller, power management logic, timer, system management bus (SMBus), universal serial bus (USB) interface, mass storage interface, low pin count (LPC) interface, wireless interconnect, direct media interface (DMI), etc.
The interconnect or bus 1155 provides interface to peripheral devices. The interconnect 1155 may be point-to-point or connected to multiple devices. For clarity, not all interconnects are shown. It is contemplated that the interconnect 1155 may include any interconnect or bus such as Peripheral Component Interconnect (PCI), PCI Express, Universal Serial Bus (USB), Small Computer System Interface (SCSI), serial SCSI, and Direct Media Interface (DMI), etc.
The mass storage interface 1170 interfaces to mass storage devices to store archive information such as code, programs, files, data, and applications. The mass storage interface may include SCSI, serial SCSI, Advanced Technology Attachment (ATA) (parallel and/or serial), Integrated Drive Electronics (IDE), enhanced IDE, ATA Packet Interface (ATAPI), etc. The mass storage device may include compact disk (CD) read-only memory (ROM) 1172, digital versatile disc (DVD) 1173, floppy drive 1174, hard drive 1175, tape drive 1176, and any other magnetic or optic storage devices. The mass storage device provides a mechanism to read machine-accessible media.
The I/O devices 11801 to 1180K may include any I/O devices to perform I/O functions. Examples of I/O devices 11801 to 1180K include controller for input devices (e.g., keyboard, mouse, trackball, pointing device, and remote control unit), media card (e.g., audio, video, and graphic), network card, and any other peripheral controllers.
Elements of one embodiment of the invention may be implemented by hardware, firmware, software or any combination thereof. The term hardware generally refers to an element having a physical structure such as electronic, electromagnetic, optical, electro-optical, mechanical, electro-mechanical parts, etc. The term software generally refers to a logical structure, a method, a procedure, a program, a routine, a process, an algorithm, a formula, a function, an expression, etc. The term firmware generally refers to a logical structure, a method, a procedure, a program, a routine, a process, an algorithm, a formula, a function, an expression, etc., that is implemented or embodied in a hardware structure (e.g., flash memory, ROM, EPROM). Examples of firmware may include microcode, writable control store, micro-programmed structure. When implemented in software or firmware, the elements of an embodiment of the present invention are essentially the code segments to perform the necessary tasks. The software/firmware may include the actual code to carry out the operations described in one embodiment of the invention, or code that emulates or simulates the operations. The program or code segments can be stored in a processor or machine accessible medium or transmitted by a computer data signal embodied in a carrier wave, or a signal modulated by a carrier, over a transmission medium. The “processor readable or accessible medium” or “machine readable or accessible medium” may include any medium that can store, transmit, or transfer information. Examples of the processor readable or machine accessible medium include an electronic circuit, a semiconductor memory device, a read only memory (ROM), a flash memory, an erasable programmable ROM (EPROM), a floppy diskette, a compact disk (CD) ROM, an optical disk, a hard disk, a fiber optic medium, a radio frequency (RF) link, etc. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc. The code segments may be downloaded via computer networks such as the Internet, Intranet, etc. The machine accessible medium may be embodied in an article of manufacture. The machine accessible medium may include information or data that, when accessed by a machine, cause the machine to perform the operations or actions described above. The machine accessible medium may also include program code embedded therein. The program code may include machine readable code to perform the operations described above. The term “information” or “data” here refers to any type of information that is encoded for machine-readable purposes. Therefore, it may include program, code, data, file, etc.
All or part of an embodiment of the invention may be implemented by hardware, software, or firmware, or any combination thereof. The hardware, software, or firmware element may have several modules coupled to one another. A hardware module is coupled to another module by mechanical, electrical, optical, electromagnetic or any physical connections. A software module is coupled to another module by a function, procedure, method, subprogram, or subroutine call, a jump, a link, a parameter, variable, and argument passing, a function return, etc. A software module is coupled to another module to receive variables, parameters, arguments, pointers, etc. and/or to generate or pass results, updated variables, pointers, etc. A firmware module is coupled to another module by any combination of hardware and software coupling methods above. A hardware, software, or firmware module may be coupled to any one of another hardware, software, or firmware module. A module may also be a software driver or interface to interact with the operating system running on the platform. A module may also be a hardware driver to configure, set up, initialize, send and receive data to and from a hardware device. An apparatus may include any combination of hardware, software, and firmware modules.
While the invention has been described in terms of several embodiments, those of ordinary skill in the art will recognize that the invention is not limited to the embodiments described, but can be practiced with modification and alteration within the spirit and scope of the appended claims. The description is thus to be regarded as illustrative instead of limiting.
This application claims the benefit of the provisional application, titled “Fast In-phase and Quadrature imbalance calibration”, filed Jun. 6, 2006, Ser. No. 60/811,579.
Number | Date | Country | |
---|---|---|---|
60811579 | Jun 2006 | US |