US20060282490A1 - Precision complex sinusoid generation using limited processing - Google Patents

Precision complex sinusoid generation using limited processing Download PDF

Info

Publication number
US20060282490A1
US20060282490A1 US11/506,360 US50636006A US2006282490A1 US 20060282490 A1 US20060282490 A1 US 20060282490A1 US 50636006 A US50636006 A US 50636006A US 2006282490 A1 US2006282490 A1 US 2006282490A1
Authority
US
United States
Prior art keywords
phasor
imaginary
real
produce
oscillator
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US11/506,360
Other versions
US7512646B2 (en
Inventor
Ganesan THIAGARAJAN
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Xylon LLC
Original Assignee
Durham Logistics LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Durham Logistics LLC filed Critical Durham Logistics LLC
Priority to US11/506,360 priority Critical patent/US7512646B2/en
Assigned to DURHAM LOGISTICS, LLC reassignment DURHAM LOGISTICS, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ARRAYCOMM, INC.
Assigned to ARRAYCOMM, INC. reassignment ARRAYCOMM, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: THIAGARAJAN, GANESAN
Publication of US20060282490A1 publication Critical patent/US20060282490A1/en
Application granted granted Critical
Publication of US7512646B2 publication Critical patent/US7512646B2/en
Assigned to XYLON LLC reassignment XYLON LLC MERGER (SEE DOCUMENT FOR DETAILS). Assignors: DURHAM LOGISTICS LLC
Adjusted expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/02Digital function generators
    • G06F1/03Digital function generators working, at least partly, by table look-up

Definitions

  • This invention relates to methods and systems for generating sinusoidal signals having application in data communication systems and other environments.
  • a first phasor associated with an electronic signal and a delta phasor associated with a cyclic rate of the electronic signal are multiplied to produce a second phasor.
  • a real and imaginary correction factor are determined and added to the second phasor.
  • the imaginary and real correction factors can be determined by first calculating the sum and difference of the real and imaginary portions of the first phasor respectively. The sum and difference are then scaled by performing simple shift-operations to produce the real and imaginary correction factors.
  • the corrected second phasor is then used to update the electronic signal, which in turn can be used to produce another signal, such as a communication signal.
  • FIG. 1 is a block diagram of an exemplary communication system with which the invention may be implemented
  • FIG. 2 is a block diagram of the exemplary transmitter of FIG. 1 ;
  • FIG. 3 is a block diagram of the exemplary oscillator of FIG. 2 ;
  • FIG. 4 is a flowchart outlining an exemplary operation for generating a complex sinusoid according to the present invention
  • FIG. 5 depicts an exemplary data-value table according to the present invention
  • FIG. 6 depicts a cosine portion of the data-value table of FIG. 5 with a number of respective inverse-denominator values
  • FIG. 7 depicts a sine portion of the data-value table of FIG. 5 with a number of respective inverse-denominator values
  • FIG. 8 depicts a cubic interpolation operation of a sine function according to the present invention.
  • FIG. 9 is a flowchart outlining a second exemplary operation for generating a complex phasor according to the present invention.
  • FIG. 1 is a block diagram of an exemplary communication system 100 that includes a transmitter 110 with a transmit antenna 120 , a transmission path 130 and a receiver 150 with a receive antenna 140 .
  • the transmitter 110 can provide a communication signal that contains digital symbol information to the transmit antenna 120 via link 112 .
  • the transmit antenna 120 can receive the transmitter's signal and effectively convey the energy of the transmitter signal in the form of a wireless communication signal, which can then be received by various devices.
  • the signal can be picked up by the receive antenna 140 and conveyed to the receiver 150 via link 142 .
  • the receiver 150 can extract the symbol information from the received signal and provide the extracted symbol information to an external device (not shown).
  • the exemplary transmitter 110 can be a wireless transmitter transmitting radio-frequency signals.
  • the transmitter 110 can be any one of a number of different transmission sources, such as in addition to a wireless RF transmitter, a transmission system employing wires, such as a twisted wire pair, a transmitter adapted for transmitting across a coaxial cable, an optical transmitter, a transmitter configured to transmit across a network, such as a telephone network or the Internet, a sonic transmitter or any other known or later developed device suitable for transmitting information.
  • the exemplary receiver 150 can be a wireless radio receiver.
  • the receiver 150 can alternatively be any one of a number of different receiving devices, such as a wireless receiver, a reception system employing wires, such as a twisted wire pair, a receiver adapted to receive signals from a coaxial cable, a receiver adapted to receive signals from a network, an optical receiver, a fiber optic receiver, a sonic receiver or any other known or later developed device suitable for receiving information.
  • the transmission path 130 can be a wireless link, a wired link, such as a 10baseT, 100baseT or Ethernet-based link, a link over an intranet, a link over an extranet, a link over the Internet, a link over a telephony-based network, an optical link, a sonic link or any other known or later developed combination of systems, conduits and devices capable of conveying information from a first location to a second location.
  • a wireless link such as a 10baseT, 100baseT or Ethernet-based link
  • a link over an intranet such as a link over an extranet
  • a link over the Internet a link over a telephony-based network
  • an optical link such as a sonic link or any other known or later developed combination of systems, conduits and devices capable of conveying information from a first location to a second location.
  • FIG. 2 is a block diagram of the exemplary transmitter 110 of FIG. 1 .
  • the exemplary, transmitter 110 includes a modulator 210 , a mixer 220 , an amplifier 230 and an oscillator 240 functional interconnected as shown.
  • the modulator 210 can receive information from an external source (not shown) via link 202 .
  • the modulator 210 can further receive a complex sinusoid from the oscillator 240 via link 242 and encode/modulate the received information.
  • the modulator 210 can pass the modulated signal to the mixer 220 via link 212 . It should be appreciated that the modulator 210 can use any known or later developed modulation technique capable of encoding information into a stream of symbols.
  • the mixer 220 can receive the modulated signal and frequency-shift the modulated signal to a radio-frequency band.
  • the mixer 220 can receive a base-band signal having a particular bandwidth and shift each frequency component of the base-band signal about a center frequency of ten megahertz.
  • the mixer 220 can provide the frequency-shifted signal to the amplifier 230 via link 222 .
  • the amplifier 230 can receive the frequency-shifted signal, amplif), and condition the frequency-shifted signal and provide the amplified/conditioned signal to an external device, such as an antenna, via link 112 .
  • FIG. 3 is a block diagram of the exemplary oscillator 240 of FIG. 2 .
  • the oscillator 240 contains a controller 410 , a memory 420 , a multiplier 430 , an arithmetic device 440 , a scaling device 450 , an adder 460 and an interface 490 coupled together through a control/data bus 402 .
  • the exemplary oscillator 240 uses a bussed structure, it should be appreciated that the oscillator 240 can be implemented using any number of architectures, such as an architecture based on fixed electronic circuits, programmable logic and the like without departing from the spirit and scope of the present invention.
  • the delta phasor e j ⁇ can be a complex number having a real portion, i.e., cos( ⁇ ), an imaginary portion, i.e., sin( ⁇ ), and unit magnitude.
  • the exemplary first phasor can be initially determined by any number of techniques or simply assigned a predetermined value, such as 1.0, and stored in the memory 420 .
  • the exemplary delta phasor can be determined using any number of techniques and stored in the memory 420 .
  • the controller 410 can take the first phasor and the delta phasor and provide the first phasor and delta phasor to the multiplier 430 .
  • the multiplier 430 can then perform a complex multiplication on the first and delta phasors to produce a second phasor, i.e., e j ⁇ n .
  • the controller 410 can provide the first phasor to the arithmetic device 440 .
  • the arithmetic device 440 can receive the first phasor, subtract the imaginary portion of the first phasor from the real portion of the first phasor to produce a first difference, and further add the real and imaginary portions of the first phasor to produce a first sum.
  • the arithmetic device 440 can provide the first sum and difference to the scaling device 450 .
  • the scaling device 450 can employ a multiplier to implement the scaling factor ⁇ in Eqs. (3) and (4).
  • a multiplier to implement the scaling factor ⁇ in Eqs. (3) and (4).
  • P is a non-zero integer set such that P satisfies Eq. (6) below 2 - P ⁇ ( 1.0 - ( cos 2 ⁇ ( ⁇ ) + sin 2 ⁇ ( ⁇ ) ) 2 ) , ( 6 ) then Eqs. (2) and (3) can be approximated by Eqs.
  • ⁇ R [cos( ⁇ ( n ⁇ 1)) ⁇ sin( ⁇ ( n ⁇ 1))]2 ⁇ (N+P)
  • ⁇ I [cos( ⁇ ( n ⁇ 1))+sin( ⁇ ( n ⁇ 1))]2 ⁇ (N+P) .
  • Eqs. (7) and (8) use a scaling factor that is an inverse integer power of 2, i.e., 2 ⁇ (N+P) .
  • the scaling device 450 can forgo a multiplier and use a simple shifting-device instead. That is, the scaling device 450 of FIG. 3 can receive the first sum and difference and subsequently shift the first sum and difference by (N+P) bits to produce the real and imaginary correction factors ⁇ R and ⁇ I. The scaling device 450 can then provide the correction factors to the adder 460 .
  • the adder 460 can receive the correction factors ⁇ R and ⁇ I and further receive the second phasor e j ⁇ n .
  • the adder 460 can then provide the corrected second phasor to an external device, such as a modulator, using the interface 490 and link 242 .
  • the exemplary interface 490 is a digital-to-analog converter capable of providing an analog electronic signal to an external device, such as a modulator or demodulator.
  • an external device such as a modulator or demodulator.
  • the interface 490 can be any known or later developed device capable of converting a digital signal to any of various forms such as a digital electronic signal, an analog electronic signal, an optical signal, a sonic signal and the like without departing from the spirit and scope of the present invention.
  • the exemplary oscillator 240 can provide a stable and accurate complex sinusoid as compared to other devices using inexpensive approaches, it should be appreciated that the oscillator's performance can benefit if the oscillator 240 occasionally opted from using the procedures outlined in Eqs. (1)-(9) in favor of using a high-accuracy technique. That is, the oscillator 240 may, in various embodiments, periodically or systematically provide a highly accurate phasor generally characterized by more expensive oscillators.
  • a number of highly accurate phasors can assure that the oscillator 240 can generate a lower-distortion and higher-stability complex sinusoid. Accordingly, in various-embodiments, it should be appreciated that the oscillator 240 can occasionally calculate a highly accurate phasor using any number of known or later developed techniques directed to complex sinusoid generation.
  • FIG. 4 is a flowchart outlining an exemplary operation for generating complex sinusoids.
  • the operation starts in step 500 where a first phasor is determined.
  • a first/initial phasor can be generated according to any known or later developed technique or simply assigned a particular value, such as 1.0.
  • a delta phasor is determined.
  • the delta phasor can be generated according to any known or later developed technique or assigned a particular value. Control continues to step 530 .
  • step 530 a determination is made as to whether to implement a high-accuracy technique, as opposed to the techniques outline in Eqs. (1)-(9) above. If a high-accuracy technique is to be used, control jumps to step 650 ; otherwise control continues to step 540 .
  • a second phasor s[n] can be generated according to any known or later technique useful to generate phasors having a high magnitude and/or phase accuracy.
  • the second phasor can be generated by assigning the second phasor with phasor values associated with key points. Control continues to step 600 .
  • step 540 the first phasor and delta phasor are multiplied to produce a second phasor.
  • step 550 the imaginary portion of the first phasor is subtracted from the real portion of the first phasor to produce a first difference.
  • step 560 the imaginary portion of the first phasor is added to the real portion of the first phasor to produce a first sum. Control continues to step 570 .
  • the first difference is scaled to produce a real correction factor.
  • the first difference can be scaled according to Eqs. (3)-(9) above and, in various exemplary embodiments, the first difference can be scaled using a shifting operation of N+P bits, as opposed to using a multiply operation.
  • the first sum is scaled to produce an imaginary correction factor.
  • the first sum can be scaled according to Eqs. (3)-(9) above and, in various exemplary embodiments, the first sum can be scaled using a shifting operation of N+P bits. Control continues to step 590 .
  • step 590 the real and imaginary correction factors are added to the real and imaginary portions of the second phasor to correct for the magnitude error of the second phasor. Control continues to step 600 .
  • step 600 the corrected/second phasor is exported to a device, such as a modulator.
  • step 610 the time index is updated. That is, first phasor is assigned the value of the corrected/second phasor.
  • step 620 a determination is made whether to continue to generate the complex sinusoid. If the complex sinusoid is to be further generated, control jumps back to step 530 ; otherwise, control continues to step 630 where the process stops.
  • Another standard/conventional technique involves generating a Taylor series approximation about a number of reference angles, then using trigonometric identities to compute the desired result. While this technique is computationally efficient, unfortunately, it can be excessively cumbersome due to various intrinsic angle operations.
  • each of the denominator-derived values c n can take a common constant value c constant and thus processing can be further simplified.
  • sine/cosine information about 27 radians can be expressed using a table containing sine or cosine data points about a single ⁇ /2 radian arc (one-quarter cycle) or alternatively, expressed using two separate tables for both sine and cosine functions about a ⁇ /4 radian arc (one-eighth cycle).
  • FIG. 5 depicts a data-value table 690 residing in a portion of memory 420 as well as a graphical representation 680 about a unit-circle of the data-values in the data-value table 690 .
  • the data-value table 690 can contain sine/cosine data-values over an arc of the unit-circle, such as arc 682 depicted on the unit-circle 680 , which ranges from 0 to 1/8 cycles. Also shown in FIG.
  • the data-value table 690 can include two extra values on each end of the arc-range (for a total of twenty data-values for each sine and cosine function) such that a polynomial interpolation of sufficiently low-order, e.g., order three, can interpolate near the data end-values.
  • exemplary data-value table 690 and Lagrange technique can use domain/angular-values expressed in cycles, radians, gradients and degrees, it should be appreciated that using angles expressed in cycles can simplify computation, maintain input precision and allow for inputs specified directly for normalized frequency units.
  • FIGS. 6 and 7 depict cosine and sine table portions 692 and 694 of the data-value table 690 of FIG. 5 paired with respective sets of denominator-values [ ⁇ 0 , . . . ⁇ 3 ] and [ ⁇ ′ 0 , . . . ⁇ ′ 3 ].
  • the exemplary sets of denominator-values [ ⁇ 0 , . . . ⁇ 3 ] and [ ⁇ ′ 0 , . . . ⁇ ′ 3 ] are centered around points x n and y n and are the product terms of Eqs. (13)-(14) above.
  • computational efficiency can be greatly increased by pre-computing inverse-denominator-values c n and c′ n according to Eq. (14) using [ ⁇ 0 , . . . ⁇ 3 ] and [ ⁇ ′ 0 , . . . ⁇ 3 ] and storing them in a memory for later retrieval.
  • the controller 410 can provide a given angular-value, i.e., a domain-value, x to the arithmetic device 440 .
  • the controller 410 can further provide N+1 number of pre-stored values [x n -y n ] describing a portion of either/both a sine and cosine function from the memory 420 to the multiplier 430 and arithmetic device 440 .
  • the arithmetic device 440 can receive the domain-value x and pre-stored values [x n , y n ], calculate the various difference-values (x-x n ) of Eq. (12) using the points [x n , y n ] surrounding x, and pass the calculated difference-values to the multiplier 430 .
  • the multiplier 430 can then pass the calculated product-values (d n (x) ⁇ y n ⁇ c n ) to the arithmetic device 440 , which in turn can add the various calculated product-values to provide the resulting sum y(x) according to Eq. (12).
  • a complex phasor (cos (x)+j(sin (x))) can be constructed.
  • the complex phasor can then be used to generate subsequent complex phasors according to Eqs. (1)-(9) above, according to FIGS. 1-4 above or used for any other task requiring a simple or complex phasor.
  • the controller 410 can export the values to an external device, such as a modulator, demodulator or frequency-shifting device via the interface 490 .
  • FIG. 8 depicts a cubic-interpolation of a data-value 850 on a sine function 830 as expressed along a domain-axis 810 and against a respective range-axis 820 .
  • the data-value 850 located at [x, y] can be accurately determined using the surrounding data-values 840 - 848 found along domain-values ⁇ x 0 . . . x 3 ⁇ .
  • a Lagrange operation outlined by Eqs. (10)-(14) can be employed to interpolate data-value 850 , and by pre-computing the denominator-value c 0 , c 1 , c 2 and c 3 according to Eq.
  • FIG. 9 is a flowchart outlining an exemplary second operation according to the present invention.
  • the process starts at step 900 where an initial phase angle (domain value) x is determined.
  • step 910 a set of respective data-values [x n , y n ] are extracted from a look-up table, such as the look-up table of FIG. 5 .
  • a look-up table may span the entire viable domain of a function or a look-up table may span a portion of a function's domain if the respective data-values can be determined from the provided domain portion. Control continues to step 920 .
  • a respective number of pre-computed inverse-denominator-values c n corresponding to data-values [x n , y n ] can be extracted from a look-up table.
  • the inverse-denominator-values c n can be unique, or in a situation where the domain-values x n are equally spaced, c n can be constant for all domain-values x n . Control continues to step 930 .
  • step 930 a Lagrange interpolation according to Eqs. (10)-(14) for a sine function is performed.
  • step 940 a Lagrange interpolation according to Eqs. (10)-(14) for a cosine function is performed.
  • step 950 the values produced in steps 930 and 940 can be combined to form a complex phasor. Control continues to step 960 .
  • step 960 the complex phasor of step 950 is exported to a device, such as a modulator in a communication device that can generate a communication signal using the sinusoid.
  • step 970 a determination is made whether to continue to generate the complex phasor. If the complex phasor is to be further generated, control jumps back to step 910 ; otherwise, control continues to step 980 where the process stops.
  • DSP digital signal processor
  • the systems and methods can also be implemented using any combination of one or more general purpose computers, special purpose computers, programmable microprocessors or microcontrollers and peripheral integrated circuit elements, hardware electronic or logic circuits, such as application specific integrated circuits (ASICs), discrete element circuits, programmable logic devices, such as a PLD, PLA, FPGA, or PAL or the like.
  • ASICs application specific integrated circuits
  • programmable logic devices such as a PLD, PLA, FPGA, or PAL or the like.
  • any device on which exists a finite state machine capable of implementing the various elements of FIGS. 1-3 and 5 - 7 and/or the flowcharts of FIGS. 4 and 8 - 9 can be used to implement the oscillator 240 functions.
  • the exemplary oscillator can be used as part of a modulator, the methods and systems of the oscillator can be applied to various other devices, such as a mixer/frequency shifter, a demodulator in a receiver and the like, without departing from the spirit and scope of the present invention.
  • a programmable device such as a computer-based system or programmable logic
  • the above-described systems and methods can be described by any of various known or later developed programming languages, such as “C”, “C44”, “FORTRAN”, Pascal”, “VHDL” and the like.
  • various storage media such as magnetic computer disks, optical disks, electronic memories and the like, can be prepared that can contain information that can direct a device to implement the above-described systems and/or methods.
  • the storage media can provide the information to the device, thus enabling the device to perform the above-described systems and/or methods.
  • the DSP could receive the information, appropriately configure itself and perform the functions of the various elements of FIGS. 1-3 and/or the flowchart of FIG. 4 to implement the oscillator 240 functions. That is, the DSP could receive various portions of information from the disk relating to different elements of the above-described systems and/or methods, implement the individual systems and/or methods and coordinate the functions of the individual systems and/or methods to generate a complex sinusoid.
  • information describing the above-described systems and methods can be provided using a communication system, such as a network or dedicated communication conduit. Accordingly, it should be appreciated that various programs, executable files or other information embodying the above-described systems and methods can be downloaded to a programmable device using any known or later developed communication technique.

Abstract

A first phasor associated with an electronic signal and a delta phasor associated with a cyclic rate of the electronic signal are multiplied to produce a second phasor. To compensate for any deviation in the magnitude of the second phasor, a real and imaginary correction factor are determined and added to the second phasor. The imaginary and real correction factors can be determined by first calculating the sum and difference of the real and imaginary portions of the first phasor respectively. The sum and difference are then scaled by performing simple shift-operations to produce the real and imaginary correction factors. The corrected second phasor is then used to update the electronic signal, which in turn can be used to produce another signal, such as a communication signal.

Description

    BACKGROUND OF THE INVENTION
  • 1. Field of Invention
  • This invention relates to methods and systems for generating sinusoidal signals having application in data communication systems and other environments.
  • 2. Description of Related Art
  • As successive generations of wireless communication systems are deployed around the world, the importance of providing clear and cost-effective communication services increases. Generally, the clarity of wireless communication systems is dependent on using precision components, such as low-distortion complex sinusoid oscillators. Although a number of low-distortion sinusoid oscillators are available, these low-distortion oscillators can be prohibitively expensive.
  • Available less expensive sinusoid oscillators may not produce complex sinusoids having the requisite distortion, precision and stability. For example, as successive points of a complex sinusoid are generated, the magnitude of the complex sinusoid can deteriorate towards zero. As a result, such oscillators are generally useful only for a short duration and cannot be used for various purposes, such as generating or decoding continuous streams of modulated data.
  • Another problem with these less expensive sinusoid oscillators is that any communication signal generated with them may be excessively distorted. Similarly, any receiver-using such sinusoid oscillators may contaminate a received signal such that the receiver will not reliably extract any information contained in the communication signal. Accordingly, there is a need for methods and systems that can provide precision complex sinusoids using an economy of electronic hardware.
  • SUMMARY OF THE INVENTION
  • In various embodiments, a first phasor associated with an electronic signal and a delta phasor associated with a cyclic rate of the electronic signal are multiplied to produce a second phasor. To compensate for any deviation in the magnitude of the second phasor, a real and imaginary correction factor are determined and added to the second phasor. The imaginary and real correction factors can be determined by first calculating the sum and difference of the real and imaginary portions of the first phasor respectively. The sum and difference are then scaled by performing simple shift-operations to produce the real and imaginary correction factors. The corrected second phasor is then used to update the electronic signal, which in turn can be used to produce another signal, such as a communication signal. Others features and advantages will become apparent from the following figures and descriptions of various embodiments.
  • DESCRIPTION OF THE DRAWINGS
  • The invention is described in detail with regard to the following figures, wherein like numerals reference like elements, and wherein:
  • FIG. 1 is a block diagram of an exemplary communication system with which the invention may be implemented;
  • FIG. 2 is a block diagram of the exemplary transmitter of FIG. 1;
  • FIG. 3 is a block diagram of the exemplary oscillator of FIG. 2;
  • FIG. 4 is a flowchart outlining an exemplary operation for generating a complex sinusoid according to the present invention;
  • FIG. 5 depicts an exemplary data-value table according to the present invention;
  • FIG. 6 depicts a cosine portion of the data-value table of FIG. 5 with a number of respective inverse-denominator values;
  • FIG. 7 depicts a sine portion of the data-value table of FIG. 5 with a number of respective inverse-denominator values;
  • FIG. 8 depicts a cubic interpolation operation of a sine function according to the present invention; and
  • FIG. 9 is a flowchart outlining a second exemplary operation for generating a complex phasor according to the present invention.
  • DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS
  • FIG. 1 is a block diagram of an exemplary communication system 100 that includes a transmitter 110 with a transmit antenna 120, a transmission path 130 and a receiver 150 with a receive antenna 140. In operation, the transmitter 110 can provide a communication signal that contains digital symbol information to the transmit antenna 120 via link 112. The transmit antenna 120 can receive the transmitter's signal and effectively convey the energy of the transmitter signal in the form of a wireless communication signal, which can then be received by various devices.
  • As the wireless communication signal propagates along path 130, the signal can be picked up by the receive antenna 140 and conveyed to the receiver 150 via link 142. Once the receiver 150 has received the wireless communication signal, the receiver 150 can extract the symbol information from the received signal and provide the extracted symbol information to an external device (not shown).
  • The exemplary transmitter 110 can be a wireless transmitter transmitting radio-frequency signals. However, in various embodiments, it should be appreciated that the transmitter 110 can be any one of a number of different transmission sources, such as in addition to a wireless RF transmitter, a transmission system employing wires, such as a twisted wire pair, a transmitter adapted for transmitting across a coaxial cable, an optical transmitter, a transmitter configured to transmit across a network, such as a telephone network or the Internet, a sonic transmitter or any other known or later developed device suitable for transmitting information.
  • Accordingly, the exemplary receiver 150 can be a wireless radio receiver. However, it should be appreciated that the receiver 150 can alternatively be any one of a number of different receiving devices, such as a wireless receiver, a reception system employing wires, such as a twisted wire pair, a receiver adapted to receive signals from a coaxial cable, a receiver adapted to receive signals from a network, an optical receiver, a fiber optic receiver, a sonic receiver or any other known or later developed device suitable for receiving information.
  • As the forms of the transmitter 1 10 and receiver 150 vary, it should be appreciated that the form of the transmission path 130 can vary accordingly. That is, in various embodiments, the transmission path 130 can be a wireless link, a wired link, such as a 10baseT, 100baseT or Ethernet-based link, a link over an intranet, a link over an extranet, a link over the Internet, a link over a telephony-based network, an optical link, a sonic link or any other known or later developed combination of systems, conduits and devices capable of conveying information from a first location to a second location.
  • FIG. 2 is a block diagram of the exemplary transmitter 110 of FIG. 1. As shown in FIG. 2, the exemplary, transmitter 110 includes a modulator 210, a mixer 220, an amplifier 230 and an oscillator 240 functional interconnected as shown. In operation, the modulator 210 can receive information from an external source (not shown) via link 202. The modulator 210 can further receive a complex sinusoid from the oscillator 240 via link 242 and encode/modulate the received information.
  • After the received information has been encoded/modulated, the modulator 210 can pass the modulated signal to the mixer 220 via link 212. It should be appreciated that the modulator 210 can use any known or later developed modulation technique capable of encoding information into a stream of symbols.
  • The mixer 220 can receive the modulated signal and frequency-shift the modulated signal to a radio-frequency band. For example, the mixer 220 can receive a base-band signal having a particular bandwidth and shift each frequency component of the base-band signal about a center frequency of ten megahertz. Once the mixer 220 has frequency-shifted the modulated signal, the mixer 220 can provide the frequency-shifted signal to the amplifier 230 via link 222.
  • The amplifier 230 can receive the frequency-shifted signal, amplif), and condition the frequency-shifted signal and provide the amplified/conditioned signal to an external device, such as an antenna, via link 112.
  • FIG. 3 is a block diagram of the exemplary oscillator 240 of FIG. 2. As shown in FIG. 3, the oscillator 240 contains a controller 410, a memory 420, a multiplier 430, an arithmetic device 440, a scaling device 450, an adder 460 and an interface 490 coupled together through a control/data bus 402. While the exemplary oscillator 240 uses a bussed structure, it should be appreciated that the oscillator 240 can be implemented using any number of architectures, such as an architecture based on fixed electronic circuits, programmable logic and the like without departing from the spirit and scope of the present invention.
  • In operation, the oscillator 240 can generate a complex sinusoid s[n] according to Eq. (1) below:
    s[n]=e jωn =e jω(n−1) *e   (1)
    where ejω(n−1) is a first phasor and e is a delta phasor. That is, ejω(n−1) is a particular representation of a complex sinusoid having a real portion, i.e., cos(ω(n−1)), and an imaginary portion, i.e., sin(ω(n−1)), and further having a magnitude of cos2(ω(n−1))+sin2(ω(n−1))=1.0. Similarly, the delta phasor e can be a complex number having a real portion, i.e., cos(ω), an imaginary portion, i.e., sin(ω), and unit magnitude.
  • The exemplary first phasor can be initially determined by any number of techniques or simply assigned a predetermined value, such as 1.0, and stored in the memory 420. Similarly, the exemplary delta phasor can be determined using any number of techniques and stored in the memory 420.
  • During operation, the controller 410 can take the first phasor and the delta phasor and provide the first phasor and delta phasor to the multiplier 430. The multiplier 430 can then perform a complex multiplication on the first and delta phasors to produce a second phasor, i.e., ejωn.
  • Next, the controller 410 can provide the first phasor to the arithmetic device 440. The arithmetic device 440 can receive the first phasor, subtract the imaginary portion of the first phasor from the real portion of the first phasor to produce a first difference, and further add the real and imaginary portions of the first phasor to produce a first sum. Next, the arithmetic device 440 can provide the first sum and difference to the scaling device 450.
  • The scaling device 450 can receive the first sum and difference and scale the first sum and difference to produce a real correction factor δR and imaginary correction factor δI according to Eqs. (2) and (3) below:
    δR=[cos(ω(n−1))−sin(ω(n−1))]α2−N   (2)
    δI=[cos(ω(n−1))+sin(ω(n−1))]α2−N   (3)
    where [cos(ω(n−1))−sin(ω(n−1))] is the first difference, [cos(ω(n−1))+sin(ω(n−1))] is the first sum, α is a predetermined scaling factor and N is the targeted/expected bit-precision of a particular oscillator.
  • In various embodiments, the scaling factor α of Eqs. (2) and (3) can be approximated according to Eq. (4) below: α = ( 1.0 - ( cos 2 ( ω ) + sin 3 ( ω ) ) 2 ) ( 4 )
    where the scaling factor α of Eq. (4) is based on the first term of the Taylor series for square roots.
  • In various embodiments, the scaling device 450 can employ a multiplier to implement the scaling factor α in Eqs. (3) and (4). However, by approximating a according to Eq. (5)
    α≅2−P,   (5)
    where P is a non-zero integer set such that P satisfies Eq. (6) below 2 - P ( 1.0 - ( cos 2 ( ω ) + sin 2 ( ω ) ) 2 ) , ( 6 )
    then Eqs. (2) and (3) can be approximated by Eqs. (7) and (8) below:
    δR=[cos(ω(n−1))−sin(ω(n−1))]2−(N+P), and   (7)
    δI=[cos(ω(n−1))+sin(ω(n−1))]2−(N+P).   (8)
  • Because Eqs. (7) and (8) use a scaling factor that is an inverse integer power of 2, i.e., 2−(N+P), it should be appreciated that the scaling device 450 can forgo a multiplier and use a simple shifting-device instead. That is, the scaling device 450 of FIG. 3 can receive the first sum and difference and subsequently shift the first sum and difference by (N+P) bits to produce the real and imaginary correction factors δR and δI. The scaling device 450 can then provide the correction factors to the adder 460.
  • The adder 460 can receive the correction factors δR and δI and further receive the second phasor ejωn. The adder 460 can then add the real correction factor to the real portion of the second phasor and add the imaginary correction factor to the imaginary portion of the second phasor to correct for magnitude errors of the second phasor to form a corrected phasor according to Eq. (9) below:
    e jωn =e jω(n−1) *e +(δR+δI)   (9)
  • The adder 460 can then provide the corrected second phasor to an external device, such as a modulator, using the interface 490 and link 242.
  • The exemplary interface 490 is a digital-to-analog converter capable of providing an analog electronic signal to an external device, such as a modulator or demodulator. However, in various embodiments, it should be appreciated that the interface 490 can be any known or later developed device capable of converting a digital signal to any of various forms such as a digital electronic signal, an analog electronic signal, an optical signal, a sonic signal and the like without departing from the spirit and scope of the present invention.
  • While the exemplary oscillator 240 can provide a stable and accurate complex sinusoid as compared to other devices using inexpensive approaches, it should be appreciated that the oscillator's performance can benefit if the oscillator 240 occasionally opted from using the procedures outlined in Eqs. (1)-(9) in favor of using a high-accuracy technique. That is, the oscillator 240 may, in various embodiments, periodically or systematically provide a highly accurate phasor generally characterized by more expensive oscillators.
  • When dispersed among phasors generated based on the procedures outlined in Eqs. (1)-(9), a number of highly accurate phasors can assure that the oscillator 240 can generate a lower-distortion and higher-stability complex sinusoid. Accordingly, in various-embodiments, it should be appreciated that the oscillator 240 can occasionally calculate a highly accurate phasor using any number of known or later developed techniques directed to complex sinusoid generation.
  • However, in other embodiments, it should be appreciated that a phasor can periodically pass through various key points, e.g., ω=0, 0.5π, π, 1.5π and 2π. Upon reaching such key points, a phasor can take the values s[n]=±1 or s[n]=±j. Assuming that the oscillator 240 can track the samples n relating to such key points, highly accurate phasors may be generated with a minimal investment of processing hardware and/or software.
  • In still other embodiments, it should be appreciated that the key points of a phasor can be values other than ω=0, 0.5π, π, 1.5π and 2π. For example, if it can be determined that a phasor will take the value s[n]=a+jb every five hundredth sample, then the oscillator 240 can simply assign s[n]=a+jb every five hundred cycles and operate according to the techniques of Eqs. (1)-(9) during the remaining cycles.
  • FIG. 4 is a flowchart outlining an exemplary operation for generating complex sinusoids. The operation starts in step 500 where a first phasor is determined. As discussed above, a first/initial phasor can be generated according to any known or later developed technique or simply assigned a particular value, such as 1.0. Next, in step 510, a delta phasor is determined. As with the first phasor, the delta phasor can be generated according to any known or later developed technique or assigned a particular value. Control continues to step 530.
  • In step 530, a determination is made as to whether to implement a high-accuracy technique, as opposed to the techniques outline in Eqs. (1)-(9) above. If a high-accuracy technique is to be used, control jumps to step 650; otherwise control continues to step 540.
  • In step 650, a second phasor s[n] can be generated according to any known or later technique useful to generate phasors having a high magnitude and/or phase accuracy. Alternatively, the second phasor can be generated by assigning the second phasor with phasor values associated with key points. Control continues to step 600.
  • Otherwise, in step 540, the first phasor and delta phasor are multiplied to produce a second phasor. Next, in step 550, the imaginary portion of the first phasor is subtracted from the real portion of the first phasor to produce a first difference. Then, in step 560, the imaginary portion of the first phasor is added to the real portion of the first phasor to produce a first sum. Control continues to step 570.
  • In step 570, the first difference is scaled to produce a real correction factor. As discussed above, the first difference can be scaled according to Eqs. (3)-(9) above and, in various exemplary embodiments, the first difference can be scaled using a shifting operation of N+P bits, as opposed to using a multiply operation. Next, in step 580, the first sum is scaled to produce an imaginary correction factor. As with the first difference, the first sum can be scaled according to Eqs. (3)-(9) above and, in various exemplary embodiments, the first sum can be scaled using a shifting operation of N+P bits. Control continues to step 590.
  • In step 590, the real and imaginary correction factors are added to the real and imaginary portions of the second phasor to correct for the magnitude error of the second phasor. Control continues to step 600.
  • In step 600, the corrected/second phasor is exported to a device, such as a modulator. Next, in step 610, the time index is updated. That is, first phasor is assigned the value of the corrected/second phasor. Then, in step 620, a determination is made whether to continue to generate the complex sinusoid. If the complex sinusoid is to be further generated, control jumps back to step 530; otherwise, control continues to step 630 where the process stops.
  • As discussed above, it can be advantageous to generate highly accurate sinusoids either alone or in conjunction with the technique outlined in Eqs. (1)-(9). One standard/conventional technique for generating sine and cosine functions would be to use a Taylor series approximation terminated past the desired number of terms required for a given bit-accuracy. Unfortunately, an excessive number of high-order polynomial terms can be required to attain the designated bit-accuracy,. Furthermore, when using finite precision electronic hardware, the coefficients of higher-order terms may be so small as to not help to contribute to the required bit-accuracy, thus limiting accuracy.
  • Another standard/conventional technique involves generating a Taylor series approximation about a number of reference angles, then using trigonometric identities to compute the desired result. While this technique is computationally efficient, unfortunately, it can be excessively cumbersome due to various intrinsic angle operations.
  • However, by adopting a Lagrange interpolation approach using a pre-computed/stored tables of sine and cosine data-values about a unit-circle, a highly accurate sinusoid (or complex sinusoid) can be generated in a straightforward process using relatively low-order polynomials. Furthermore by specifying that the sine and cosine data-values be equally-spaced about the unit-circle, much of the processing required for any given phasor can be greatly simplified and pre-computed such that pre-computed portions of the Lagrange interpolation approach can be stored and later repetitively extracted for subsequent use. Accordingly, as various phasors are generated using such a carefully modified Lagrange approach, the required processing can be greatly reduced.
  • Generally, a Lagrange interpolation approach can take the form of Eq. (10) below: y ( x ) = n = 0 N b n ( x ) y n , b n ( x ) = m = 0 , m 0 N ( ( x - x n ) ( x n - x m ) ) , ( 10 )
    where N is the desired order of the Lagrange interpolation, xn are the domain-values for a set of data points [xn, yn] describing a function, such as a sine or cosine function, yn are range-values corresponding to each domain-value and x is a domain-variable angle/value along the domain of the function. Equation (10) above can be expressed in an expanded form of Eq. (11) below: y ( x ) = ( ( x - x 1 ) ( x - x 2 ) ( x - x N ) ( x 0 - x 1 ) ( x 0 - x 2 ) ( x 0 - x N ) ) y 0 + ( ( x - x 0 ) ( x - x 2 ) ( x - x N ) ( x 1 - x 0 ) ( x 1 - x 2 ) ( x 1 - x N ) ) y 1 + ( 11 )
  • Because the domain-values {x0 . . . xN} are known and non-variable values, it should be appreciated that any denominator-value using, only these known and non-variable values can be pre-computed. Accordingly, denominator-values need be computed once and stored such that each subsequent Lagrange interpolation of any point about a function can take advantage of the pre-computed denominators, thus improving computational efficiency. That is, Eq. (10) above can be reduced to Eq. (12) below: y ( x ) = n = 0 N c n d n ( x ) y n , d n ( x ) = m = 0 , m 0 N ( x - x n ) , ( 12 )
    where each cn is an inverse-denominator value that can pre-computed according to Eq. (13) below: c n = m = 0 , m 0 N 1 ( x n - x m ) . ( 13 )
  • Observing Eq. (13), it should be appreciated that, by choosing data-values {x0 . . . xN} such that |xk-xk+1|=constant, i.e., the data-values are equally-spaced, Eq. (13) can be reduced to Eq. (14) below: c n = m = 0 , m 0 N 1 ( δ m ) = c constant . ( 14 )
  • Accordingly, for each domain-value x, each of the denominator-derived values cn can take a common constant value cconstant and thus processing can be further simplified.
  • In the present embodiment, assuming that the data-values of a pre-computed table describing a sine/cosine (or other) function are equally-spaced, it can be shown that an angular-spacing of π/64 (128th of a sinusoidal cycle) about the unit-circle can suffice to produce a 24-bit accurate sine or cosine function for a third-order Lagrange polynomial. Accordingly, two tables of 128 data-values each can suffice to generate 24-bit accurate phasors for sine and cosine functions.
  • However, given that various waveforms, such as sine and cosine functions, are highly symmetric, it should be appreciated that sine/cosine information about 27 radians (one cycle) can be expressed using a table containing sine or cosine data points about a single π/2 radian arc (one-quarter cycle) or alternatively, expressed using two separate tables for both sine and cosine functions about a π/4 radian arc (one-eighth cycle).
  • FIG. 5 depicts a data-value table 690 residing in a portion of memory 420 as well as a graphical representation 680 about a unit-circle of the data-values in the data-value table 690. As shown in FIG. 5, the data-value table 690 can contain sine/cosine data-values over an arc of the unit-circle, such as arc 682 depicted on the unit-circle 680, which ranges from 0 to 1/8 cycles. Also shown in FIG. 5, besides containing sixteen sine/cosine data-values ranging from 0 to 1/8 cycles, the data-value table 690 can include two extra values on each end of the arc-range (for a total of twenty data-values for each sine and cosine function) such that a polynomial interpolation of sufficiently low-order, e.g., order three, can interpolate near the data end-values.
  • While the exemplary data-value table 690 and Lagrange technique can use domain/angular-values expressed in cycles, radians, gradients and degrees, it should be appreciated that using angles expressed in cycles can simplify computation, maintain input precision and allow for inputs specified directly for normalized frequency units.
  • Still further, although the exemplary data-value table 690 is configured to use a cubic Lagrange technique, i.e., N=3, it should be appreciated that the particular Lagrange order along with the particular configuration of the data-value table 690 can vary without departing from the spirit and scope of the present invention. However, it has been determined by experimentation that an order of N=3 is sufficient to achieve 24-bit accuracy. Although a larger-order operation may also achieve sufficient accuracy, it should be appreciated that as the order increases, computational complexity increases as well.
  • FIGS. 6 and 7 depict cosine and sine table portions 692 and 694 of the data-value table 690 of FIG. 5 paired with respective sets of denominator-values [δ0, . . . δ3] and [δ′0, . . . δ′3]. The exemplary sets of denominator-values [δ0, . . . δ3] and [δ′0, . . . δ′3] are centered around points xn and yn and are the product terms of Eqs. (13)-(14) above. As earlier discussed, computational efficiency can be greatly increased by pre-computing inverse-denominator-values cn and c′n according to Eq. (14) using [δ0, . . . δ3] and [δ′0, . . . δ3] and storing them in a memory for later retrieval. Also as earlier discussed, assuming that the domain-values of tables 522-524 are equally-spaced, processing can be further simplified as c′n=cn=constant for all n=0, . . . N.
  • Returning to FIG. 3, to produce a high-accuracy phasor, the controller 410 can provide a given angular-value, i.e., a domain-value, x to the arithmetic device 440. The controller 410 can further provide N+1 number of pre-stored values [xn-yn] describing a portion of either/both a sine and cosine function from the memory 420 to the multiplier 430 and arithmetic device 440.
  • The arithmetic device 440 can receive the domain-value x and pre-stored values [xn, yn], calculate the various difference-values (x-xn) of Eq. (12) using the points [xn, yn] surrounding x, and pass the calculated difference-values to the multiplier 430.
  • The multiplier 430 can receive the calculated difference-values (x-xn), further receive the respective range-values yn and inverse-denominator-values cn, (which can be retrieved from memory 420) and calculate the product-values (dn(x)×yn×cn) of Eq. (12) for each value n=0 . . . N. The multiplier 430 can then pass the calculated product-values (dn(x)×yn×cn) to the arithmetic device 440, which in turn can add the various calculated product-values to provide the resulting sum y(x) according to Eq. (12).
  • Assuming that the multiplier 430 and arithmetic device 440 operate to determine both the sine and cosine values for a given angle x, a complex phasor=(cos (x)+j(sin (x))) can be constructed. The complex phasor can then be used to generate subsequent complex phasors according to Eqs. (1)-(9) above, according to FIGS. 1-4 above or used for any other task requiring a simple or complex phasor.
  • As the multiplier 430 and arithmetic device 440 generate any number of values of a sinusoid, the controller 410 can export the values to an external device, such as a modulator, demodulator or frequency-shifting device via the interface 490.
  • FIG. 8 depicts a cubic-interpolation of a data-value 850 on a sine function 830 as expressed along a domain-axis 810 and against a respective range-axis 820. As shown in FIG. 8, the data-value 850, located at [x, y], can be accurately determined using the surrounding data-values 840-848 found along domain-values {x0 . . . x3}. As discussed above, a Lagrange operation outlined by Eqs. (10)-(14) can be employed to interpolate data-value 850, and by pre-computing the denominator-value c0, c1, c2 and c3 according to Eq. (14), processing can be made more efficient. Still further, assuming that each reference point along domain-values {x0 . . . x3} is equally spaced, cn can be a constant for all denominator-values.
  • FIG. 9 is a flowchart outlining an exemplary second operation according to the present invention. As shown in FIG. 9, the process starts at step 900 where an initial phase angle (domain value) x is determined. Next, in step 910, a set of respective data-values [xn, yn] are extracted from a look-up table, such as the look-up table of FIG. 5. As discussed above, a look-up table may span the entire viable domain of a function or a look-up table may span a portion of a function's domain if the respective data-values can be determined from the provided domain portion. Control continues to step 920.
  • In step 920 a respective number of pre-computed inverse-denominator-values cn corresponding to data-values [xn, yn] can be extracted from a look-up table. As discussed above, the inverse-denominator-values cn can be unique, or in a situation where the domain-values xn are equally spaced, cn can be constant for all domain-values xn. Control continues to step 930.
  • In step 930, a Lagrange interpolation according to Eqs. (10)-(14) for a sine function is performed. Next, in step 940, a Lagrange interpolation according to Eqs. (10)-(14) for a cosine function is performed. Then, in step 950, the values produced in steps 930 and 940 can be combined to form a complex phasor. Control continues to step 960.
  • In step 960, the complex phasor of step 950 is exported to a device, such as a modulator in a communication device that can generate a communication signal using the sinusoid. Next, in step 970, a determination is made whether to continue to generate the complex phasor. If the complex phasor is to be further generated, control jumps back to step 910; otherwise, control continues to step 980 where the process stops.
  • It should be appreciated that the various above-described systems and methods are preferably implemented on a digital signal processor (DSP) or other integrated circuits. However, the systems and methods can also be implemented using any combination of one or more general purpose computers, special purpose computers, programmable microprocessors or microcontrollers and peripheral integrated circuit elements, hardware electronic or logic circuits, such as application specific integrated circuits (ASICs), discrete element circuits, programmable logic devices, such as a PLD, PLA, FPGA, or PAL or the like. In general, any device on which exists a finite state machine capable of implementing the various elements of FIGS. 1-3 and 5-7 and/or the flowcharts of FIGS. 4 and 8-9 can be used to implement the oscillator 240 functions.
  • It should further be noted that while the exemplary oscillator can be used as part of a modulator, the methods and systems of the oscillator can be applied to various other devices, such as a mixer/frequency shifter, a demodulator in a receiver and the like, without departing from the spirit and scope of the present invention. In various embodiments where the above-described systems and/or methods are implemented using a programmable device, such as a computer-based system or programmable logic, it should be appreciated that the above-described systems and methods can be described by any of various known or later developed programming languages, such as “C”, “C44”, “FORTRAN”, Pascal”, “VHDL” and the like.
  • Accordingly, various storage media, such as magnetic computer disks, optical disks, electronic memories and the like, can be prepared that can contain information that can direct a device to implement the above-described systems and/or methods. Once an appropriately capable device has access to the information contained on the storage media, the storage media can provide the information to the device, thus enabling the device to perform the above-described systems and/or methods.
  • For example, if a computer disk containing the appropriate information, such as a source file, an object file, an executable file or the like, were provided to a DSP, the DSP could receive the information, appropriately configure itself and perform the functions of the various elements of FIGS. 1-3 and/or the flowchart of FIG. 4 to implement the oscillator 240 functions. That is, the DSP could receive various portions of information from the disk relating to different elements of the above-described systems and/or methods, implement the individual systems and/or methods and coordinate the functions of the individual systems and/or methods to generate a complex sinusoid.
  • In still other embodiments, rather than providing a fixed storage media, such as a magnetic-disk, information describing the above-described systems and methods can be provided using a communication system, such as a network or dedicated communication conduit. Accordingly, it should be appreciated that various programs, executable files or other information embodying the above-described systems and methods can be downloaded to a programmable device using any known or later developed communication technique.
  • While this invention has been described in conjunction with the specific embodiments thereof, it is evident that many alternatives, modifications, and variations will be apparent to those skilled in the art. Accordingly, preferred embodiments of the invention as set forth herein are intended to be illustrative, not limiting. There are changes that may be made without departing from the spirit and scope of the invention.

Claims (13)

1-34. (canceled)
35. A transmitter comprising:
a modulator adapted to modulate a signal for transmission on a transmission medium based, at least in part, on information and in response to a complex sinusoid;
an oscillator adapted to:
generate a second phasor based, at least in part, on multiplying together a first phasor associated with the complex sinusoid with a delta phasor associated with a cyclic rate of the complex, the first phasor having a first real portion and a first imaginary portion, the second phasor having a second real portion and a second imaginary portion;
combine the first imaginary portion with the first real portion to produce a first sum;
scale the first sum according to a first scaling factor to produce an imaginary correction factor;
combine the imaginary correction factor with the second imaginary portion of the second phasor to correct for a magnitude error of the second phasor; and
update the complex sinusoid based, at least in part, on the corrected second phasor.
36. The transmitter of claim 35, wherein said oscillator is further adapted to:
subtract the first imaginary portion from the first real portion to produce a first difference;
scale the first difference according to the first scaling factor to produce a real correction factor; and
combine the real correction factor with the second real portion of the second phasor to further correct for the magnitude error of the second phasor.
37. The transmitter of claim 35, wherein said oscillator is further adapted to scale said first sum using a shift operation.
38. A receiver comprising:
a demodulator adapted to demodulate a signal received from a transmission medium to recover information in response to a complex sinusoid;
an oscillator adapted to:
generate a second phasor based, at least in part, on multiplying together a first phasor associated with the complex sinusoid with a delta phasor associated with a cyclic rate of the complex, the first phasor having a first real portion and a first imaginary portion, the second phasor having a second real portion and a second imaginary portion;
combine the first imaginary portion with the first real portion to produce a first sum;
scale the first sum according to a first scaling factor to produce an imaginary correction factor;
combine the imaginary correction factor with the second imaginary portion of the second phasor to correct for a magnitude error of the second phasor; and
update the complex sinusoid based, at least in part, on the corrected second phasor.
39. The receiver of claim 38, wherein said oscillator is further adapted to:
subtract the first imaginary portion from the first real portion to produce a first difference;
scale the first difference according to the first scaling factor to produce a real correction factor; and
combine the real correction factor with the second real portion of the second phasor to further correct for the magnitude error of the second phasor.
40. The receiver of claim 38, wherein said oscillator is further adapted to scale said first sum using a shift operation.
41. A system comprising:
a transmitter adapted to transmit information in a transmission medium according to an Internet protocol, the transmitter comprising:
a modulator adapted to modulate a signal for transmission on said transmission medium based, at least in part, on said information and in response to
a complex sinusoid;
an oscillator adapted to:
generate a second phasor based, at least in part, on multiplying together a first phasor associated with the complex sinusoid with a delta phasor associated with a cyclic rate of the complex sinusoid, the first phasor having a first real portion and a first imaginary portion, the second phasor having a second real portion and a second imaginary portion;
combine the first imaginary portion with the first real portion to produce a first sum;
scale the first sum according to a first scaling factor to produce an imaginary correction factor;
combine the imaginary correction factor with the second imaginary portion of the second phasor to correct for a magnitude error of the second phasor; and
update the complex sinusoid based, at least in part, on the corrected second phasor; and
a receiver adapted to receive said signal from said transmission medium and recover said information therefrom.
42. The system of claim 41, wherein said oscillator is further adapted to:
subtract the first imaginary portion from the first real portion to produce a first difference;
scale the first difference according to the first scaling factor to produce a real correction factor; and
combine the real correction factor with the second real portion of the second phasor to further correct for the magnitude error of the second phasor.
43. The system of claim 41, wherein said oscillator is further adapted to scale said first sum using a shift operation.
44. A system comprising:
a transmitter adapted to transmit information in a transmission medium according to an Internet protocol, the transmitter comprising:
a modulator adapted to modulate a signal for transmission on said transmission medium based, at least in part, on said information and in response to a complex sinusoid;
an oscillator adapted to:
generate a second phasor based, at least in part, on multiplying together a first phasor associated with the complex sinusoid with a delta phasor associated with a cyclic rate of the complex, the first phasor having a first real portion and a first imaginary portion, the second phasor having a second real portion and a second imaginary portion;
combine the first imaginary portion with the first real portion to produce a first sum;
scale the first sum according to a first scaling factor to produce an imaginary correction factor;
combine the imaginary correction factor with the second imaginary portion of the second phasor to correct for a magnitude error of the second phasor; and
update the complex sinusoid based, at least in part, on the corrected second phasor; and
a receiver adapted to receive said signal from said transmission medium and recover said information therefrom.
42. The system of claim 44, wherein said oscillator is further adapted to:
subtract the first imaginary portion from the first real portion to produce a first difference;
scale the first difference according to the first scaling factor to produce a real correction factor; and
combine the real correction factor with the second real portion of the second phasor to further correct for the magnitude error of the second phasor.
43. The system of claim 44, wherein said oscillator is further adapted to scale said first sum using a shift operation.
US11/506,360 2001-10-01 2006-08-18 Precision complex sinusoid generation using limited processing Expired - Lifetime US7512646B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/506,360 US7512646B2 (en) 2001-10-01 2006-08-18 Precision complex sinusoid generation using limited processing

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/966,103 US7240083B1 (en) 2001-10-01 2001-10-01 Precision complex sinusoid generation using limited processing
US11/506,360 US7512646B2 (en) 2001-10-01 2006-08-18 Precision complex sinusoid generation using limited processing

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/966,103 Continuation US7240083B1 (en) 2001-10-01 2001-10-01 Precision complex sinusoid generation using limited processing

Publications (2)

Publication Number Publication Date
US20060282490A1 true US20060282490A1 (en) 2006-12-14
US7512646B2 US7512646B2 (en) 2009-03-31

Family

ID=37525316

Family Applications (2)

Application Number Title Priority Date Filing Date
US09/966,103 Expired - Fee Related US7240083B1 (en) 2001-10-01 2001-10-01 Precision complex sinusoid generation using limited processing
US11/506,360 Expired - Lifetime US7512646B2 (en) 2001-10-01 2006-08-18 Precision complex sinusoid generation using limited processing

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/966,103 Expired - Fee Related US7240083B1 (en) 2001-10-01 2001-10-01 Precision complex sinusoid generation using limited processing

Country Status (1)

Country Link
US (2) US7240083B1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20160091607A (en) 2015-01-26 2016-08-03 삼성전자주식회사 Image processing apparatus, ultrasonic apparatus including the same and control method for the same

Citations (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3633017A (en) * 1970-01-07 1972-01-04 Sperry Rand Corp Digital waveform generator
US3674998A (en) * 1970-03-04 1972-07-04 Varian Associates Method and apparatus for automatic phase control in a fourier analyzed readout of impulse resonance data
US4577287A (en) * 1983-03-02 1986-03-18 At&T Bell Laboratories Method and apparatus for generating digital signals representing periodic samples of a sine wave
US4878187A (en) * 1988-06-22 1989-10-31 The Board Of Trustees Of The Leland Stanford Junior University Apparatus and method for generating a sequence of sines or cosines
US5068816A (en) * 1990-02-16 1991-11-26 Noetzel Andrew S Interplating memory function evaluation
US5530720A (en) * 1993-07-01 1996-06-25 Alcatel Espace Method of calculating weighting coefficients for an analytical digitizer for signal processing, and analytical digitizer
US5699383A (en) * 1995-03-06 1997-12-16 Nec Corporation High-power linear amplification using periodically updated amplitude and phase correction values
US5732107A (en) * 1995-08-31 1998-03-24 Northrop Grumman Corporation Fir interpolator with zero order hold and fir-spline interpolation combination
US6311046B1 (en) * 1998-04-02 2001-10-30 Ericsson Inc. Linear amplification systems and methods using more than two constant length vectors
US6385632B1 (en) * 1999-06-18 2002-05-07 Advanced Micro Devices, Inc. Fast CORDIC algorithm with sine governed termination
US6426977B1 (en) * 1999-06-04 2002-07-30 Atlantic Aerospace Electronics Corporation System and method for applying and removing Gaussian covering functions
US6483459B1 (en) * 2001-04-05 2002-11-19 Neoreach, Inc. Direction of arrival angle tracking algorithm for smart antennas
US6640237B1 (en) * 1999-07-27 2003-10-28 Raytheon Company Method and system for generating a trigonometric function

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH1057374A (en) * 1996-06-11 1998-03-03 Olympus Optical Co Ltd Ultrasonograph

Patent Citations (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3633017A (en) * 1970-01-07 1972-01-04 Sperry Rand Corp Digital waveform generator
US3674998A (en) * 1970-03-04 1972-07-04 Varian Associates Method and apparatus for automatic phase control in a fourier analyzed readout of impulse resonance data
US4577287A (en) * 1983-03-02 1986-03-18 At&T Bell Laboratories Method and apparatus for generating digital signals representing periodic samples of a sine wave
US4878187A (en) * 1988-06-22 1989-10-31 The Board Of Trustees Of The Leland Stanford Junior University Apparatus and method for generating a sequence of sines or cosines
US5068816A (en) * 1990-02-16 1991-11-26 Noetzel Andrew S Interplating memory function evaluation
US5530720A (en) * 1993-07-01 1996-06-25 Alcatel Espace Method of calculating weighting coefficients for an analytical digitizer for signal processing, and analytical digitizer
US5699383A (en) * 1995-03-06 1997-12-16 Nec Corporation High-power linear amplification using periodically updated amplitude and phase correction values
US5732107A (en) * 1995-08-31 1998-03-24 Northrop Grumman Corporation Fir interpolator with zero order hold and fir-spline interpolation combination
US6311046B1 (en) * 1998-04-02 2001-10-30 Ericsson Inc. Linear amplification systems and methods using more than two constant length vectors
US6426977B1 (en) * 1999-06-04 2002-07-30 Atlantic Aerospace Electronics Corporation System and method for applying and removing Gaussian covering functions
US6385632B1 (en) * 1999-06-18 2002-05-07 Advanced Micro Devices, Inc. Fast CORDIC algorithm with sine governed termination
US6640237B1 (en) * 1999-07-27 2003-10-28 Raytheon Company Method and system for generating a trigonometric function
US6483459B1 (en) * 2001-04-05 2002-11-19 Neoreach, Inc. Direction of arrival angle tracking algorithm for smart antennas

Also Published As

Publication number Publication date
US7512646B2 (en) 2009-03-31
US7240083B1 (en) 2007-07-03

Similar Documents

Publication Publication Date Title
CA2050350C (en) Method of compensating for non-linearities in an end amplifier incorporated in a radio transmitter
US6665338B1 (en) Circuitry for converting a sampled digital signal to a naturally sampled digital signal and method therefor
EP0423666B1 (en) Digital non-linearity correction method for a transmission chain, and device for carrying out the method
US6981011B1 (en) Precision complex sinusoid generation using limited processing
US7512646B2 (en) Precision complex sinusoid generation using limited processing
Poletti The homomorphic analytic signal
EP0808029A3 (en) Apparatus for determining an error locator polynomial for use in a Reed-Solomon decoder
WO2008072555A1 (en) Sinusoidal wave generation circuit
JPH1075122A (en) Method for demodulating fm signal and device therefor
US7676529B2 (en) System and method for efficient rectangular to polar signal conversion using cordic algorithm
US4646321A (en) Interpolation pulse duration modulated adder
Katkar et al. Realization of cordic algorithm in DDS: Novel Approch towards Digital Modulators in MATLAB and VHDL
Gonzalez et al. Digital signal generation for LFM-LPI radars
Godbole et al. FPGA implementation of CORDIC algorithm used in DDS based modulators
Loughlin Do bounded signals have bounded amplitudes?
EP1586027B1 (en) Superposition of waves using the cordic algorithm
US9467174B2 (en) Low complexity high-order syndrome calculator for block codes and method of calculating high-order syndrome
JPH10508406A (en) Low complexity signal processing device and receiver having the signal processing device
JP2739318B2 (en) Maximum likelihood receiver
CA2606597A1 (en) Rf broadcasting employing sinusoidal-cosine wave generation with plural look-up tables
JP3206773B2 (en) Digital signal processing quadrature modulator
KR100487354B1 (en) Method of digital minimum shift keying modulation and apparatus of the same and modulation system using the same
DOBIÁŠ DRM Transmitter with FPGA Device
US7583638B2 (en) Device and method for processing a digital data signal in a CDMA radio transmitter
Chaudhari Analytical methods for the performance evaluation of binary linear block codes

Legal Events

Date Code Title Description
AS Assignment

Owner name: ARRAYCOMM, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:THIAGARAJAN, GANESAN;REEL/FRAME:018197/0186

Effective date: 20010927

Owner name: DURHAM LOGISTICS, LLC, NEVADA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ARRAYCOMM, INC.;REEL/FRAME:018213/0813

Effective date: 20041206

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: XYLON LLC, NEVADA

Free format text: MERGER;ASSIGNOR:DURHAM LOGISTICS LLC;REEL/FRAME:036743/0770

Effective date: 20150813

FPAY Fee payment

Year of fee payment: 8

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12