Embodiments of the present invention can provide circuits and systems for computing a discrete Fourier transform (DFT) or an inverse discrete Fourier transform (IDFT). An embodiment includes an input circuit, an intermediate circuit, an output circuit, and an accumulator circuit. The input circuit can receive a set of input values, and can use a first set of degenerate rotators to generate a first set of intermediate values. The intermediate circuit can receive the first set of intermediate values, and can use a set of cordics (coordinate rotation digital computers) to generate a second set of intermediate values. The output circuit can receive the second set of intermediate values, and can use a second set of degenerate rotators to generate a third set of intermediate values. The accumulator circuit can receive the third set of intermediate values, and can use a set of accumulators to generate a set of output values.
|
1. A circuit, comprising:
an input circuit to generate a first set of intermediate values in parallel by performing rotations and additions on a set of input values, wherein the input circuit includes a first set of degenerate rotators to perform said rotations, wherein each degenerate rotator in the first set of degenerate rotators performs a rotation by π/2r, where r is an integer, and wherein the cardinality of the first set of intermediate values is less than the cardinality of the set of input values;
an intermediate circuit to generate a second set of intermediate values in parallel by rotating the first set of intermediate values using a set of cordics (coordinate rotation digital computers) configured to operate in parallel, wherein the cardinality of the set of cordics is equal to the cardinalities of the sets of first and second intermediate values;
an angle-generating circuit which generates a set of angle values in parallel, wherein each angle value in the set of angle values is provided as an input to a corresponding cordic in the set of cordics;
an output circuit to generate a third set of intermediate values in parallel by performing rotations on the second set of intermediate values, wherein the output circuit includes a second set of degenerate rotators, wherein each degenerate rotator in the second set of degenerate rotators performs a rotation by π/2r, where r is an integer, and wherein the cardinality of the third set of intermediate values is greater than the cardinality of the second set of intermediate values; and
an accumulator circuit, comprising a set of accumulators configured to operate in parallel, to generate a set of output values based on the third set of intermediate values.
15. A system, comprising:
a processor;
a memory; and
a circuit, which includes:
an input circuit to generate a first set of intermediate values in parallel by performing rotations and additions on a set of input values, wherein the input circuit includes a first set of degenerate rotators to perform said rotations, wherein each degenerate rotator in the first set of degenerate rotators performs a rotation by π/2r, where r is an integer, and wherein the cardinality of the first set of intermediate values is less than the cardinality of the set of input values;
an intermediate circuit to generate a second set of intermediate values in parallel by rotating the first set of intermediate values using a set of cordics (coordinate rotation digital computers) configured to operate in parallel, wherein the cardinality of the set of cordics is equal to the cardinalities of the sets of first and second intermediate values;
an angle-generating circuit which generates a set of angle values in parallel, wherein each angle value in the set of angle values is provided as an input to a corresponding cordic in the set of cordics;
an output circuit to generate a third set of intermediate values in parallel by performing rotations on the second set of intermediate values, wherein the output circuit includes a second set of degenerate rotators, wherein each degenerate rotator in the second set of degenerate rotators performs a rotation by π/2r, where r is an integer, and wherein the cardinality of the third set of intermediate values is greater than the cardinality of the second set of intermediate values; and
an accumulator circuit, comprising a set of accumulators configured to operate in parallel, to generate a set of output values based on the third set of intermediate values.
8. A non-transitory computer-readable storage medium storing instructions for implementing a circuit, the circuit comprising:
an input circuit to generate a first set of intermediate values in parallel by performing rotations and additions on a set of input values, wherein the input circuit includes a first set of degenerate rotators to perform said rotations, wherein each degenerate rotator in the first set of degenerate rotators performs a rotation by π/2r, where r is an integer, and wherein the cardinality of the first set of intermediate values is less than the cardinality of the set of input values;
an intermediate circuit to generate a second set of intermediate values in parallel by rotating the first set of intermediate values using a set of cordics (coordinate rotation digital computers) configured to operate in parallel, wherein the cardinality of the set of cordics is equal to the cardinalities of the sets of first and second intermediate values;
an angle-generating circuit which generates a set of angle values in parallel, wherein each angle value in the set of angle values is provided as an input to a corresponding cordic in the set of cordics;
an output circuit to generate a third set of intermediate values in parallel by performing rotations on the second set of intermediate values, wherein the output circuit includes a second set of degenerate rotators, wherein each degenerate rotator in the second set of degenerate rotators performs a rotation by π/2r, where r is an integer, and wherein the cardinality of the third set of intermediate values is greater than the cardinality of the second set of intermediate values; and
an accumulator circuit, comprising a set of accumulators configured to operate in parallel, to generate a set of output values based on the third set of intermediate values.
2. The circuit of
a first modulo circuit which generates a first modulo value, wherein the input circuit uses the first modulo value to generate the first set of intermediate values;
a second modulo circuit which generates a second modulo value, wherein the output circuit uses the second modulo value to generate the third set of intermediate values; and
a clearing circuit which generates a signal, wherein the accumulator circuit uses the signal to clear the set of accumulators.
3. The circuit of
4. The circuit of
a π rotator;
a π/2 rotator;
a π/4 rotator; and
a π/8 rotator.
5. The circuit of
6. The circuit of
7. The circuit of
9. The non-transitory computer-readable storage medium of
a first modulo circuit which generates a first modulo value, wherein the input circuit uses the first modulo value to generate the first set of intermediate values;
a second modulo circuit which generates a second modulo value, wherein the output circuit uses the second modulo value to generate the third set of intermediate values; and
a clearing circuit which generates a signal, wherein the accumulator circuit uses the signal to clear the set of accumulators.
10. The non-transitory computer-readable storage medium of
11. The non-transitory computer-readable storage medium of
a π rotator;
a π/2 rotator;
a π/4 rotator; and
a π/8 rotator.
12. The non-transitory computer-readable storage medium of
13. The non-transitory computer-readable storage medium of
14. The non-transitory computer-readable storage medium of
16. The system of
a first modulo circuit which generates a first modulo value, wherein the input circuit uses the first modulo value to generate the first set of intermediate values;
a second modulo circuit which generates a second modulo value, wherein the output circuit uses the second modulo value to generate the third set of intermediate values; and
a clearing circuit which generates a signal, wherein the accumulator circuit uses the signal to clear the set of accumulators.
17. The system of
a π rotator;
a π/2 rotator;
a π/4 rotator; and
a π/8 rotator.
18. The system of
19. The system of
20. The system of
|
1. Field of the Invention
The present invention relates to integrated circuit design. Specifically, the present invention relates to a digital hardware that can be used to determine a discrete Fourier transform (DFT) or an inverse discrete Fourier transform (IDFT).
2. Related Art
Discrete Fourier transform (DFT) and inverse discrete Fourier transform (IDFT) are used in a wide range of applications, such as, signal processing, image processing, data compression, etc., for transforming signals from time domain to frequency domain and vice-versa.
Exponential increase in networking bandwidth and storage capacity has created a need for high throughput DFT/IDFT circuits. Further, low complexity circuits are preferable over high complexity circuits, since, in general, they consume less power and are less expensive from the silicon real-estate perspective. Hence, low complexity DFT/IDFT circuits that have a high throughput are desirable.
One embodiment of the present invention provides a system for computing a DFT or an IDFT. An embodiment uses a DFT or an IDFT formulation as the starting point instead of using a FFT (fast Fourier transform) or using an IFFT (inverse fast Fourier transform) formulation as the starting point. Terms in the DFT or IDFT formulation are re-arranged so that the embodiment has low complexity and high throughput.
Embodiments of the present invention can be used in a wide range of applications, such as: signal processing, image processing, video processing, electrical communication, etc.
Integrated Circuit (IC) Design Flow
The process starts with the conception of the product idea (stage 100) which is realized using an EDA software design process (stage 110). When the design is finalized, it can be taped-out (event 140). After tape out, the fabrication process (stage 150) and packaging and assembly processes (stage 160) are performed which ultimately result in finished chips (result 170).
The EDA software design process (stage 110), in turn, comprises stages 112-130, which are described below. Note that the design flow description is for illustration purposes only. This description is not meant to limit the present invention. For example, an actual integrated circuit design may require the designer to perform the design stages in a different sequence than the sequence described below. The following discussion provides further details of the stages in the design process.
System design (stage 112): In this stage, the designers describe the functionality they want to implement. They can also perform what-if planning to refine functionality, check cost, etc. This stage can also involve floating to fixed point conversion and fixing of data bus widths at various stages of the design to ensure that, with fixed point truncation, the performance goals in terms of signal to quantization noise ratio are satisfied. Hardware-software architecture partitioning can occur at this stage. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include Saber, System Studio, and DesignWare® products.
Logic design and functional verification (stage 114): At this stage, the VHDL or Verilog code for modules in the system is written and the design is checked for functional accuracy. More specifically, the design can be checked to ensure that it produces the correct outputs by comparing the output from the HDL description with that from the golden fixed point model created in stage 112. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include VCS, VERA, DesignWare®, Magellan, Formality, ESP and LEDA products.
Synthesis and design for test (stage 116): Here, the VHDL/Verilog is translated to a netlist. The netlist can be optimized for the target technology. Additionally, tests can be designed and implemented to check the finished chips. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include Design Compiler®, Physical Compiler, Test Compiler, Power Compiler, FPGA Compiler, Tetramax, and DesignWare® products.
Netlist verification (stage 1118): At this stage, the netlist is checked for compliance with timing constraints and for correspondence with the VHDL/Verilog source code. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include Formality, PrimeTime, and VCS products.
Design planning (stage 120): Here, an overall floorplan for the chip is constructed and analyzed for timing and top-level routing. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include Astro and IC Compiler products.
Physical implementation (stage 122): Placement (positioning of circuit elements) and routing (connection of the same) occur at this stage. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include the Astro and IC Compiler products.
Analysis and extraction (stage 124): At this stage, the circuit function is verified at a transistor level, this in turn permits what-if refinement. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include AstroRail, PrimeRail, Primetime, and Star RC/XT products.
Physical verification (stage 126): In this stage, the design is checked to ensure correctness for manufacturing, electrical issues, lithographic issues, and circuitry. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include the Hercules product.
Resolution enhancement (stage 128): This stage involves geometric manipulations of the layout to improve manufacturability of the design. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include Proteus, ProteusAF, and PSMGen products.
Mask data preparation (stage 130): This stage provides the “tape-out” data for production of masks to produce finished chips. Exemplary EDA software products from Synopsys, Inc. that can be used at this stage include the CATS(R) family of products.
Embodiments of the present invention can be used during one or more of the above-described stages. Specifically, one embodiment of the present invention can be used during the system design stage 112.
DFT Computation
Conventional techniques for computing a DFT typically use variations of the Cooley-Turkey algorithm for Fast Fourier Transform (FFT). However, these techniques usually suffer from the following issues which limit their applicability in applications that require very high throughput, for example 528 Msps128 point FFT required by Multiband OFDM (orthogonal frequency division multiplexing) modems:
To summarize, conventional techniques are usually not good for designing low complexity circuits that can perform DFT/IDFT computations at high throughputs.
One embodiment of the present invention includes a low complexity circuit that performs DFT computations at high throughputs. An embodiment may employ:
The circuit illustrated in
Input circuit 202 receives a set of input values which can be a subset of a larger set of input values. The circuit shown in
For example, the circuit shown in
Input circuit 202 can include a first set of degenerate rotators. In one embodiment, a degenerate rotator receives a complex number as input and rotates the complex number by an angle π/2r, where r is an integer. Input circuit 202 can use the first set of degenerate rotators to generate a first set of intermediate values, namely, x′(n,k), x′(n,k+4), x′(n,k+8), and x′(n,k+12). Note that input circuit 202 may receive the value of “k” as an input. In the embodiment shown in
Intermediate circuit 204 can receive the set of intermediate values that were generated by input circuit 202. Intermediate circuit 204 can include CORDICs (coordinate rotation digital computers), such as CORDICs 210, 212, 214, and 216. Intermediate circuit 204 can use the CORDICs to generate a second set of intermediate values, namely, y′(n,k), y′(n,k+4), y′(n,k+8), and y′(n,k+12). A CORDIC receives a complex number as input and rotates the complex number by an angle, which can be supplied as an input to the CORDIC. For example, CORDICs 210, 212, 214, and 216 rotate values x′(n,k), x′(n,k+4), x′(n,k+8), and x′(n,k+12), respectively, by angles, A0(n, k), A1(n, k), A2(n, k), and A3(n, k), respectively. Note that intermediate circuit 204 may receive the above angles as inputs.
Output circuit 206 can receive the second set of intermediate values that were generated by intermediate circuit 204. Output circuit 206 can include a second set of degenerate rotators. Output circuit 206 can use the second set of degenerate rotators to generate a third set of intermediate values (which may be complex), namely, Y(n, k), Y(n, k+4), Y(n, k+8), . . . , Y(n, k+116), Y(n, k+120), Y(n, k+124). Note that in the embodiment shown in
Accumulator circuit 208 can receive the third set of intermediate values that were generated by output circuit 206. Accumulator circuit 208 can include accumulators 218, 220, 222, 224, 226, and 228. An accumulator can receive an input value and can add the input value to the value stored in the accumulator. Note that the accumulator's input value may be a complex number and the value stored in the accumulator may also be a complex number. Accumulator circuit 208 can use the accumulators to generate a set of output values, namely, X(k+0), X(k+4), X(k+8), . . . , X(k+116), X(k+120), X(k+124). The number of accumulators can be same as the degree of parallelism of the output circuit. For irregularly scheduled operation, accumulator circuit 208 may receive an external “INIT” signal 230 which it can use to clear the set of accumulators.
The π rotator shown in
When k0=0, the multiplexer selects the top multiplexer input s0, and when k0=1, the multiplexer selects the bottom multiplexer input s1. Hereinafter, all multiplexers are configured to select the top input when the control bit is 0, and to select the bottom input when the control bit is 1.
A multiplexer can generally be any circuit that couples an input with an output, wherein the multiplexer selects the input from a set of inputs using a set of control bits. A sign-changer can generally be any circuit that receives an input value, and generates an output value by changing the sign of the input value.
The π/2 rotator shown in
The addition, subtraction, and sign changing operations can be performed in two's complement format. Further, a sign changer can prevent overflow by outputting value 2(N−1) when the input is equal to −2N.
The π/4 rotator shown in
The π/4 rotator can also comprise adders and subtracters, such as, adder 520 and subtracter 522. An adder can generally be any circuit whose output is equal to the summation of its inputs. A subtracter can generally be any circuit whose output is equal to the difference between its inputs. In one embodiment an adder and a subtracter can be realized using the same type of circuit, e.g., an adder-subtracter circuit. Note that some multiplexers shown in
The π/8 rotator shown in
Recall that the circuit shown in
Clk
n
k
0
0
0
1
1
0
2
2
0
3
3
0
4
4
0
5
5
0
6
6
0
7
7
0
8
0
1
9
1
1
10
2
1
11
3
1
12
4
1
13
5
1
14
6
1
15
7
1
16
0
2
17
1
2
18
2
2
19
3
2
20
4
2
21
5
2
22
6
2
23
7
2
24
0
3
25
1
3
26
2
3
27
3
3
28
4
3
29
5
3
30
6
3
31
7
3
The circuit shown in
Modulo-8 synchronous counter 702 can be used to generate modulo value n={n2, n1, n0}, where n0 is the LSB. This modulo value can then be used by output circuit 206 (shown in
Recall that CORDICs 210, 212, 214, and 216 in
Angle-generating circuit 802 can generally be any circuit that can generate the angle values in accordance with the above expressions. The angle can be represented as a 7-bit unsigned binary and computed as nk, n(k+4), n(k+8), and n(k+12). An embodiment may not require a negative angle and thus unsigned representation may suffice. We may need to ensure that the reference angle representation inside the CORDICs is also consistent. If the CORDICs require negative angle values, an unsigned to two's complement extension would suffice.
The circuit shown in
Recall that accumulator circuit 208 shown in
The circuit shown in
IDFT Formulation
The following expressions illustrate the relationship between the various input values and output values shown in
An IDFT can be expressed as:
where, X(k) is the IDFT of x(n), 0≦k, n≦127, and
The other outputs of input circuit 202, namely, x′(n,k+4), x′(n,k+8), and x′(n,k+12), can be expressed as:
The outputs of intermediate circuit 204, can be expressed as:
Eight of the 32 outputs of output circuit 206 can be expressed as:
Output circuit 206 generates 32 Y values in each clock cycle. Expressions for eight of those Y values are shown in equation (8). The other 24 Y values can be similarly expressed in terms of y′(n,k+4), y′(n,k+8), and y′(n,k+12). For example, eight more Y values can be expressed in terms of y′(n,k+4) as follows:
Finally, the 32 output values of accumulator circuit 208 can be expressed as follows:
Note that an IDFT can be expressed as:
On the other hand, a DFT can be expressed as:
By comparing equations (11) and (12) we note that an IDFT circuit can be used as a DFT circuit by swapping the real and imaginary channels of the inputs and the outputs. Specifically, the IDFT circuit shown in
In one embodiment, a single circuit can be used for performing both IDFT operations as well as DFT operations. For example, the data from a receiver and a transmitter can be interleaved and the circuit can alternately perform IDFT computations for the transmitter data and DFT computations for the receiver data. The circuit shown in
Using Degenerate Rotators
Note that equations (3)-(6) specify how input circuit 202 can use degenerate rotators to produce the input circuit 202's outputs. Similarly, equations (8)-(9) specify how output circuit 206 can use degenerate rotators to produce the output circuit 206's outputs.
As shown in
Inputs x(n+88) and x(n+120) can be fed into π rotators 1104 and 1106 to generate values x(n+88)ejπk and x(n+120)ejπk, respectively. Next, adders 1116 and 1118 can be used to add these values with inputs x(n+24) and x(n+56), respectively, to generate values (x(n+24)+x(n+88)ejπk) and (x(n+56)+x(n+120)ejπk), respectively. Next, the value (x(n+56)+x(n+120)ejπk) can be fed into π/2 rotator 1108 to generate value (x(n+56)+x(n+120)ejπk)ejπk/2. Next, adder 1120 can be used to add (x(n+56)+x(n+120)ejπk)/2 with the output of adder 1116 to generate value ((x(n+24)+x(n+88)ejπk)+(x(n+56)+x(n+120)ejπk)ejπk/2). Finally, this value can be fed into 3π/8 rotator 1110 to obtain output value 1102 which corresponds to the value of the expression 1002 shown in
The circuit illustrated in
The input timing illustrates how the input values are received by input circuit 202. Note that input circuit 202 receives the 128 input values four times over 32 clock cycles using 16 parallel input lines. The output timing illustrates how the output values are generated by the accumulator circuit 208. Note that the DFT/IDFT circuit generates the 128 output values in four sets, wherein each set contains 32 output values.
Embodiments of the present invention can be used to perform DFT/IDFT computation in burst mode as well as continuous mode. A ping-pong memory of depth 128 can be used at both the input and output interfaces of the DFT/IDFT circuit. A ping-pong memory is typically used in conventional FFT implementations.
In both burst mode as well as continuous mode, the resets need to be cleared. Specifically, in burst mode the clearing can be performed whenever the next set of inputs are processed. In continuous mode, the clearing can be performed at periodic intervals. Appropriate reset logic architecture can be created so that resets to all pipeline stages are just in time.
System 1302 can include DFT/IDFT circuit 1304. System 1302 can also include processor 1306 and memory 1308. The components within system 1302 can communicate with one another using a bus or a switch or any other communication mechanism. DFT/IDFT circuit 1304 and/or system 1302 can be used in a wide range of applications, including, but not limited to, signal processing, image processing, video processing, spectral analysis, and data communication.
Generalized Equations
The foregoing descriptions of embodiments of the present invention have been presented only for purposes of illustration and description. They are not intended to be exhaustive or to limit the present invention to the forms disclosed. Accordingly, many modifications and variations will be readily apparent to practitioners skilled in the art.
Specifically, the following set of expressions can be used to design a DFT/IDFT circuit that uses a given number of CORDICs and that operates on a given number of inputs.
Let the number of points (i.e., the number of inputs or outputs) in the DFT/IDFT be 2N. Further, let the number of clock cycles required for computing the DFT/IDFT be 2M, where M<N (assuming the ideal case of no pipeline requirement). Hence, in 2M cycles, 2N points need to be calculated, each requiring 2N inputs. Further, let the number of CORDICs be equal to 2P, where P<M.
Consider two scenarios. In the first scenario, the output circuit should not contain any degenerate rotors that are associated with an angle that is less than π/2S. In this scenario, we can have 2P+S+1 parallel outputs. Let us assume that we have a degree of parallelism of 2K at the input side. Hence, all 2N input values can be fed into the DFT/IDFT circuit every 2N−K clock cycles, and 2J=2P+S+1 values can be output in parallel. Assuming that we do not require any processing margin (i.e., the ideal case of no pipelining), the following relation holds:
Note that the above expression bounds the degree of input parallelism in terms of the output constraints. In one embodiment, the DFT/IDFT circuit can input 2K values in each clock cycle that are selected with uniform spacing from the total 2N inputs. In other words, in the ath clock cycle, the input circuit can receive the values {x(a+2N−Kb), 0≦a<2N−K, 0≦b<2K} as inputs.
The second scenario occurs when the input circuit should not contain any degenerate rotors that are associated with an angle that is less than π/2S. In this scenario, all 2N inputs can be fed into the DFT/IDFT circuit every 2N−S−1 clock cycles, and 2J values can be output in parallel. Assuming that we do not require any processing margin (i.e., the ideal case of no pipelining), the following relation holds:
The above expression bounds the degree of output parallelism in terms of the input constraints. Note that it may not be possible to fulfill both constraints simultaneously for a given M.
A generalized version of equations (3)-(6) is as follows. We compute {x′(a,k+2K−Pb), 0≦a<2N−K, 0≦b<2P, 0≦k<2N−J} by iteratively expanding the expressions as follows:
A generalized version of equation (7) is as follows. The expressions for {y′(a,k+2K−Pb), 0≦a<2N−K, 0≦b<2, 0≦k<2N−P−S−1} values are given by:
Assuming that the degree of output parallelism is 2J, where J>P, each CORDIC is responsible for 2J−P equally spaced outputs. Hence, a generalized version of equations (8)-(9) is given by the following expression:
Finally, a generalized version of equation (10) is given by the following expression:
It will be apparent to one skilled in the art that generalized equations (13)-(17) can be used to design a DFT/IDFT circuit based on a given set of constraints. The DFT/IDFT circuit shown in
Furthermore, the present invention is not limited to embodiments in which the number of inputs is a power of 2. When the number of inputs is not equal to a power of 2, some terms may not be able to be grouped, and these leftover terms may need to be processed through the CORDICs separately. However, the basic design philosophy of the circuit is still valid, i.e., group terms in pairs separated by angles π, π/2, π/4, π/8, etc., pass them through the CORDICs, etc. Note that an interesting scenario arises when the number of data points is 2k (2n+1). In this case, the input circuit can group some terms in threes instead of pairs, thereby avoiding leftover terms.
The data structures and code described in this detailed description are typically stored on a computer-readable storage medium, which may be any device or medium that can store code and/or data for use by a computer system. This includes, but is not limited to, volatile memory, non-volatile memory, magnetic and optical storage devices such as disk drives, magnetic tape, CDs (compact discs), DVDs (digital versatile discs or digital video discs), or other media capable of storing computer readable media now known or later developed.
Furthermore, the foregoing descriptions of embodiments of the present invention have been presented only for purposes of illustration and description. They are not intended to be exhaustive or to limit the present invention to the forms disclosed. Accordingly, many modifications and variations will be readily apparent to practitioners skilled in the art. Additionally, the above disclosure is not intended to limit the present invention. The scope of the present invention is defined by the appended claims.
Balasubramanian, Sriram, Ray, Baijayanta, Krishnan, Venkataraghavan Punnapakkam, Seetharaman, Dalavaipatnam Rangarao
Patent | Priority | Assignee | Title |
10847211, | Apr 18 2018 | ARM Limited | Latch circuitry for memory applications |
Patent | Priority | Assignee | Title |
3965343, | Mar 03 1975 | The United States of America as represented by the Secretary of the Navy | Modular system for performing the discrete fourier transform via the chirp-Z transform |
4601006, | Oct 06 1983 | RESEARCH CORPORATION TECHNOLOGIES, INC , A NONPROFIT CORP OF DE; UNIVERSITY OF NORTH CAROLINA, THE, NORTH CAROLINA STATE UNIVERSITY | Architecture for two dimensional fast fourier transform |
4896287, | May 31 1988 | General Electric Company | Cordic complex multiplier |
6085077, | Jan 21 1997 | AIR FORCE, UNITED STATES | Hardware efficient digital channelized receiver |
6098088, | Nov 17 1995 | Teracom AB | Real-time pipeline fast fourier transform processors |
6466958, | Sep 12 2000 | L-3 Communications Corporation | Parallel frequency searching in an acquisition correlator |
6611231, | Apr 27 2001 | XR Communications, LLC | Wireless packet switched communication systems and networks using adaptively steered antenna arrays |
6643678, | Sep 12 2000 | L-3 Communications Corporation | Correction of code drift in a non-coherent memory |
7020218, | Jun 18 2001 | THOMSON LICENSING S A ; THOMSON INC | Sliding-window transform with integrated windowing |
20070266070, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 09 2007 | KRISHNAN, VENKATARAGHAVAN PUNNAPAKKAM | Synopsys, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 019367 | /0660 | |
May 09 2007 | BALASUBRAMANIAN, SRIRAM | Synopsys, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 019367 | /0660 | |
May 10 2007 | RAY, BAIJAYANTA | Synopsys, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 019367 | /0660 | |
May 10 2007 | SEETHARAMAN, DALAVAIPATNAM RANGARAO | Synopsys, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 019367 | /0660 | |
May 11 2007 | Synopsys, Inc. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Dec 29 2016 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Dec 18 2020 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Dec 21 2024 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Jul 09 2016 | 4 years fee payment window open |
Jan 09 2017 | 6 months grace period start (w surcharge) |
Jul 09 2017 | patent expiry (for year 4) |
Jul 09 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jul 09 2020 | 8 years fee payment window open |
Jan 09 2021 | 6 months grace period start (w surcharge) |
Jul 09 2021 | patent expiry (for year 8) |
Jul 09 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jul 09 2024 | 12 years fee payment window open |
Jan 09 2025 | 6 months grace period start (w surcharge) |
Jul 09 2025 | patent expiry (for year 12) |
Jul 09 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |