Discrete Fourier transformation processor based on complex radix (−1+j) number system  by Shadap, Anidaphi & Saha, Prabir
Engineering Science and Technology, an International Journal xxx (2016) xxx–xxxContents lists available at ScienceDirect
Engineering Science and Technology,
an International Journal
journal homepage: www.elsevier .com/ locate / jestchFull Length ArticleDiscrete Fourier transformation processor based on complex radix
(1 + j) number systemhttp://dx.doi.org/10.1016/j.jestch.2016.08.020
2215-0986/ 2016 Karabuk University. Publishing services by Elsevier B.V.
This is an open access article under the CC BY-NC-ND license (http://creativecommons.org/licenses/by-nc-nd/4.0/).
⇑ Corresponding author.
E-mail addresses: anidaphishadap@nitm.ac.in (A. Shadap), sahaprabir1@gmail.
com (P. Saha).
Peer review under responsibility of Karabuk University.
Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transformation processor based on complex radix (1 + j) number system, E
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020Anidaphi Shadap, Prabir Saha ⇑
Department of Electronics and Communication Engineering, National Institute of Technology Meghalaya, Shillong 793003, India
a r t i c l e i n f o a b s t r a c tArticle history:
Received 25 May 2016
Revised 29 August 2016
Accepted 29 August 2016
Available online xxxx
Keywords:
Complex binary number system (CNBS)
Conversion algorithms
Complex number
Discrete Fourier transformation (DFT)
Radix
IntegerComplex radix (1 + j) allows the arithmetic operations of complex numbers to be done without treating
the divide and conquer rules, which offers the significant speed improvement of complex numbers com-
putation circuitry. Design and hardware implementation of complex radix (1 + j) converter has been
introduced in this paper. Extensive simulation results have been incorporated and an application of this
converter towards the implementation of discrete Fourier transformation (DFT) processor has been pre-
sented. The functionality of the DFT processor have been verified in Xilinx ISE design suite version 14.7
and performance parameters like propagation delay and dynamic switching power consumption have
been calculated by Virtuoso platform in Cadence. The proposed DFT processor has been implemented
through conversion, multiplication and addition. The performance parameter matrix in terms of delay
and power consumption offered a significant improvement over other traditional implementation of
DFT processor.
 2016 Karabuk University. Publishing services by Elsevier B.V. This is an open access article under the CC
BY-NC-ND license (http://creativecommons.org/licenses/by-nc-nd/4.0/).1. Introduction
Back in 1960, D.E. Knuth presented the quarter imaginary num-
ber system with the help of radix 2j and established a unique way
of complex number representation through digit sets like 0,1,2,3
[1]. Advancement of research in 1964, W. Penny represented com-
plex numbers using base -4 [2] and later on extended his research
on the base (1 + j) [3]. It has been testified that complex number
can be treated as single binary string using the base (1 + j).
Moreover, the representation offers similar binary addition rules
with some exception.
Substantial amount of research have so far been established for
the conversion of decimal number to quarter imaginary number
[1–4]. W.J. Gilbert [4] proposed that each complex numbers can
be represented in positional notation using certain complex bases
like (1 ± j), (1j), 2j, etc. It has been observed that (1 + j) is a
good radix because the pattern covers the entire complex plane
[4]. Later on, T. Jamil et al. has invigorated the conversion algo-
rithm based on the radix (1 + j) in the year 2000 [5]. Besides
the conversion algorithm, the work has been extended for hard-
ware implementation of the arithmetic operations like addition,
subtraction, multiplication and division [5–12].However circuitry for performing arithmetic operations of com-
plex numbers based on complex base (1 + j) have been proposed
so far, but circuitry for the representation from decimal number to
complex base number have not been introduced till now. In this
paper gate level implementation of the converter facilitating deci-
mal to complex base number (1 + j) have been introduced. 8-bit
binary input has been applied to the converter, which offered
20-bits value in complex radix (1 + j). The converter has been
designed based on the division method of binary numbers where
the last two bits (starting from least significant bit (LSB)) are taken
as remainder in each iterations, and rest of the bit string have been
considered as quotient. Basic components like 3:8 decoder, full
adders, half adders, multiplexors and compressors [11] have been
considered to make up the converter.
The implemented converter has been applied for the implemen-
tation discrete Fourier transformation [12–22] processor. The pro-
posed DFT processor has been implemented through conversion,
multiplication and addition. The reported DFT processor has been
compared with three different methodologies like distributed
arithmetic (DA) [20], systolic array (SA) [19], and CORDIC [21]
based implementation. Gate level implementation of the circuit
has been carried out for its functionality test. Moreover the circuit
functionality has been verified by Xilinx ISE design suite version
14.7. Performance parameters like propagation delay and dynamic
switching power consumption has been calculated by NC Launch
platform in Cadence. Simulation results of 8 point DFT processorng. Sci.
8 bit binary 
input
(-1+j) Converter
Shift left
<<1
Positive Integer
In base (-1+j)
Adder for base  
(-1+j)
Positive imaginary in base 
(-1+j)
Adder for base  
(-1+j)
Shift left
<<2
Negative imaginary in base 
(-1+j)
Shift left
<<2
2 A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxxhave been measured as 109 ns propagation delay along-with
89 mW dynamic power consumption. Moreover, proposed design
is 40% faster than DA and 43% faster than SA based implementation
respectively.
2. Review of complex binary number system (CBNS)
A complex number ðAþ jBÞ can be represented by the radix
(1 + j) using the positional notation similar to radix 2 representa-
tion [2,5]. An n bit number whose radix is (1 + j) can be
represented in the form of a power series
Aþ jB ¼ an1ð1þ jÞn1 þ an2ð1þ jÞn2 þ . . .þ a1ð1þ jÞ1
þ a0ð1þ jÞ0 ð1Þ
where the coefficients an1,an2,. . .,a2,a1,a0 are binary bits (0 or 1).
Let us consider two numbers (based on radix (1 + j)) 1011 and
1100 whose exact decimal values are 2 + 3j and 2 respectively.
The illustration has been shown here under:
1011 ¼ 1ð1þ jÞ3 þ 0ð1þ jÞ2 þ 1ð1þ jÞ1 þ 1ð1þ jÞ0 ¼ 2þ 3j
1100 ¼ 1ð1þ jÞ3 þ 1ð1þ jÞ2 þ 0ð1þ jÞ1 þ 0ð1þ jÞ0 ¼ 2
The addition rule for complex base number is very similar to the
binary with some exception. The addition process is illustrated in
Table 1.
2.1. Conversion algorithm for integer to CBNS (positive and negative)
To represent a positive integer into CBNS, the following steps
are followed:
 Convert the integer into radix 4 representation. This can be
implemented through successive division process. Mathemati-
cally steps can be represented as
½X10 ¼
XK
i¼0
xi4
i; ð2Þ
where xi8ð0;1;2;3Þ.
 Convert the radix 4 number to radix (-4) number by introducing
a negative sign into odd places taken from least significant digit.
 Normalize the number obtained in step 2 i.e., the digits has to
be in the range 0 to 3. This is done by repeatedly adding 4 to
the negative digits and adding a 1 to the digit on its left. If the
digit is 4, replace it by a zero and subtract a one from the digit
on its left.
 Finally replace each digit value with the corresponding four-bit
sequence ð0 ! 0000;1! 0001;2! 1100;3! 1101Þ
To fully understand the algorithm let us assume an example:
200base10 when divided by 4 the digits (3, 0, 2, 0) base4 are
obtained. When these digits are converted to base -4 the digits
(3, 0, 2, 0) base-4 are obtained.
The next step which is normalization is performed, from this
the digits (1, 1, 1, 2, 0) are obtained and replacing each digit by
the string of four bit i.e., (0001 0001 0001 1100 0000) which is
the final results. For a negative integer the obtained result aboveTable 1
Addition Rule in Base (1 + j).
Binary Number 1 Binary Number 2 Addition Result
0 0 0
0 1 1
1 0 1
1 1 1100
Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020is with 11101 which is equivalent to 1 i.e. (0001 0001 0001
1100 0000  11101 = 200.
2.2. Conversion algorithm for complex numbers to CBNS
For imaginary numbers we simply multiply the positive integer
obtained in Section 2.1 by 11 which is j in base (1 + j) and 111
which is (–j) in base (1 + j).
i.e. ð0001 0001 0001 1100 0000  11Þ ¼ 00011001100000100
0000 ¼ ð200jÞ
and ð0001 0001 0001 1100 0000  111Þ ¼ 000111011101110
1000000 ¼ ð200jÞ
3. Hardware implementation of the converter
Hardware implementation procedure of the conversion has
been described in this section. The design flow of the converter is
shown in Fig. 1. Input of the converter has been considered as
8-bit string, which will be converted to complex base number.
From Fig. 1, it has been observed that 8-bit string of binary number
has been applied to the input of the converter to get 20-bit radix
(1 + j) output. The converted output bits have been shifted once
to the left to get the imaginary numbers. Finally converted output
and the shifted version of the output has been added with the help
of a special adder based on radix (1 + j) which has been designed
for this purpose (shown in Section 3.4) to obtain the positive imag-
inary number which is in base (1 + j).
The positive real number has been left shifted two times, and
added with the positive imaginary base number to get the negative
imaginary base number. The multiplication has been obtained by
shifting and addition algorithm. To get the negative real number,
the positive real number has to be multiplied with 11101 starting
from the LSB. The last three digits is nothing but the negative imag-
inary number hence, the negative imaginary number is shifted toAdder for base  
(-1+j)
Negative integer in base 
(-1+j)
Fig. 1. Design flow diagram.
ation processor based on complex radix (1 + j) number system, Eng. Sci.
Fig. 2. Architecture of the integer to base (1 + j) base converter for positive
integer.
A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxx 3the left twice and added with the positive real number using the
same adder used above.
3.1. Converter for positive real number
The first step of the conversion algorithms [1] is based on binary
division principle. The architecture has been implemented through
successive division by 4, and remainder has been calculated. For an
8 bit binary number ((X ¼P7i¼0xi2i), rightmost bits i.e. ðx1; x0Þ can
be considered as remainder, and rest bits can be considered as quo-
tient, when divide by 4. Next remainder can be computed as
ðx3; x2Þ, and the process continues until the MSB appears. Flowchart
of the design is shown in Fig. 2, where input has been considered as
8-bit binary number.
The architecture is made up of 5 blocks as shown in Fig. 3 viz.
Fig. 3(a)–(e). Fig. 3(a) converts radix (base) 2 to radix (base) 4 rep-
resentation; i.e. the circuit for obtaining the remainders when the
input is divided by 4. It is an 8 bit parallel in parallel out register
made up of D flip flops shown in Fig. 3(a). Moreover, the input
can be fed towards the input of the radix (base) - 4 of the circuit.
The second block [Fig. 3(b)] which is the base 4 to base (-4) circuit
is a 20s complement circuit, which will account for negating at the
odd bits. This is done by giving only the bits which are at the odd
positions obtained from the first block i.e. if the remainders
obtained from the first block.
The third block [Fig. 3(c)] which is a circuit for base (-4) to digits
representation circuitry; has been implemented through a 3bit
serial adder. These adders have been used for addition of the odd
position digits with 4 and the leftmost of the odd digit with 1.
The fourth block [Fig. 3(d)] is needed when obtained digits has a
number 4; then the step is to replace 4 by 0 and subtract 1 from the
left. The circuitry has been implemented through 3:8 decoders, 2:1
multiplexer and a 20s complement circuit. The input of the decoder
has been taken from the output of the adder circuit from Fig. 3(c).
When input number is (100)2, this will select act as a selection of
the multiplexer. At the same time the output line of the decoder
is enabled and will select the register storing the values 0000. So
this way 4 is replaced by 0 and for subtraction of 1 from the left,
the same output line is given as select to the 2:1 multiplexer which
will select 1 or 0 based on selection line of the multiplexer. The
output of the multiplexer is again fed to the input to a 20s comple-
ment circuitry.Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020The last block [Fig. 3(e)] which will select the equivalent bits
representation in base (1 + j) is a sequence of register which will
store the values 0000, 0001, 1100 and 1101 to represent the digits
0,1,2,3 respectively. Only these digits are considered because after
applying the algorithm the digits obtained always falls between
(0–3). It will depend on the output from the adders which will
be given to the decoder and then the output of the decoder will
act as an enable to the registers.
3.2. Converter for imaginary numbers
To obtain the imaginary numbers, positive integer is multiplied
with 11 for positive imaginary and 111 for negative imaginary. In
base (1 + j), 11 is equivalent to j and 111 is equivalent to –j.
Now, instead of using a multiplier that eventually increase the
hardware complexity; shifting and adding have been utilized.
Whatever digits obtained from the converter shown in Section 3.1
is shifted to the left two times if a positive imaginary is needed and
then the shifted bits are added using the complex base adder
shown in Section 3.1. The adder has been implemented through
half adders, full adders, 4:2 compressors and 5:2 compressors. To
get the negative imaginary numbers positive imaginary number
have been shifted once and added with the previous one.
3.3. Converter for negative real number
To get the negative integers, positive integer is multiplied by
11101 which is equivalent to (1) in base (1 + j). In Section 3.2
the negative imaginary is obtained by shifting 3 times and adding
which is multiplication by 111. So for obtaining the negative real
the last three shifts are omitted because this is nothing but the
negative imaginary number obtained in Section 3.2. So just by sim-
ply shifting this negative imaginary by 2 times and adding this
with the positive real number obtained in Section 3.1 the negative
real number is obtained.
3.4. Adder for obtaining imaginary and negative integers
Adder implementation hardware has been shown in Fig. 4. This
special adder has been implemented through binary half adders,
full adders and compressors [11]. The adder is designed based on
the addition rule [shown in Table 1] in complex binary number
system where the carry is being propagated to the (nth + 2) and
(nth + 3) positions. The converter outputs taken from Fig. 3, is
given as input to this adder to obtain the negative real part and
the positive and negative imaginary part of the complex number.
4. Application: Discrete Fourier transformation (DFT)
The Discrete Fourier Transform (DFT) of discrete signal x(n) can
be directly computed as:
XðkÞ ¼
XN1
n¼0
xðnÞwnkN for k ¼ 0 : N  1 ð3Þ
where WN (twiddle factor) can be expressed as
wN ¼ ej2pN ¼ cos 2pN  j sin 2pN
The Eq. (3) can be represented in the form of a matrix below
X½0
X½1
X½2
..
.
X½N  1
2
66666664
3
77777775
¼
1 1 1    1
1 w1N w
2
N    wN1N
1 w2N w
4
N    w2ðN1ÞN
..
. ..
. ..
.    ...
1 wN1N w
2ðN1Þ
N    wðN1ÞðN1ÞN
2
66666664
3
77777775
xð0Þ
xð1Þ
xð2Þ
..
.
xðN  1Þ
2
66666664
3
77777775
ð4Þation processor based on complex radix (1 + j) number system, Eng. Sci.
4 A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxxAn efficient DFT computation method significantly reduces the
number of required arithmetic operations is called fast Fourier
transformation (FFT) [12–20]. An FFT algorithm divides the DFT
calculation into many short-length DFTs and results in huge
savings of computations [13]. If the length of DFT N = Rv, i.e., the
product of identical factors, the corresponding FFT algorithms are
called Radix-R algorithms.
4.1. Hardware implementation
The implemented block diagram of the DFT structure is shown
in Fig. 5. The structure comprises of the (1 + j) base converter for
generation of input vectors as well as twiddle factors. The output of
this converter is then multiplied with the twiddle factors using theFull Adder Full Adder Full Adder
1B00B10B2
S0S1S2Cout 
Cin=0
Add 1 circuit
3:8
decoder
0
2's com
0
From base (-4) to digit 
circuit
To the ne
subtrac
from
(a)
(b)
(c)
(d)
Fig. 3. (a): Radix (base) 2 to radix (base) 4 conversion circuit. (b): Radix (base) 4 to
Replacement circuit for digit 4. (e): Circuit for digit representation in base (1 + j).
Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020complex multiplier and then the result is added using the complex
adder to get the final output. The multiplication and addition is
done based on complex radix algorithm.
4.2. Examples for implementation
For N = 2 and N = 4 multiplication is not required because the
coefficient of the twiddle factor involved is 1 (either positive or
negative). The converter outputs will both positive and negative
real & positive and negative imaginary outputs, that have been
handled carefully for multiplication purpose. So, eventually when
this output is multiplied with a twiddle factor of 1 the result will
be the input itself. Literally this means nothing but addition of
the input vectors generated using the converter. So when the twid-Full Adder Full Adder Full Adder
0B00B11B2
S0S1S2Cout 
Cin=
0
Add 4 circuit
0 1
2:1 
mux
plement
0
Circuit for digit 
representaon 
in base (-1+j)
xt digit for 
on of 1 
 le
radix (base) -4 circuit. (c): Radix (base) – 4 to digit representation circuit. 3 (d):
ation processor based on complex radix (1 + j) number system, Eng. Sci.
Fig. 3 (continued)
A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxx 5dle factor of 1 is involved there is no need for multiplication. This
will be justified by taking a DFT of length N = 4, as follows
X½0
X½1
X½2
X½3
2
6666664
3
7777775
¼
w04 w
0
4 w
0
4 w
0
4
w04 w
1
4 w
2
4 w
3
4
w04 w
2
4 w
4
4 w
6
4
w04 w
3
4 w
6
4 w
9
4
2
6666664
3
7777775

xð0Þ
xð1Þ
xð2Þ
xð3Þ
2
6666664
3
7777775
¼
1 1 1 1
1 j 1 j
1 1 1 1
1 j 1 j
2
6666664
3
7777775

xð0Þ
xð1Þ
xð2Þ
xð3Þ
2
6666664
3
7777775
¼
xð0Þ þ xð1Þ þ xð2Þ þ xð3Þ
xð0Þ þ ½jxð1Þ þ ½xð2Þ þ ½jxð3Þ
xð0Þ þ ½xð1Þ þ xð2Þ þ xð3Þ
xð0Þ þ ½jxð1Þ þ ½xð2Þ þ ½jxð3Þ
2
6666664
3
7777775
ð5ÞX½0
X½1
X½2
X½3
X½4
X½5
X½6
X½7
2
66666666666664
3
77777777777775
¼
1 1 1 1 1
1 ð0:707 0:707jÞ j ð0:707 0:707jÞ 1 ð0
1 j 1 j 1
1 ð0:707 0:707jÞ j ð0:707 0:707jÞ 1 ð0:
1 1 1 1 1
1 ð0:707þ 0:707jÞ 1 ð0:707þ 0:707jÞ 1 ð0:
1 j 1 j 1
1 ð0:707þ 0:707jÞ j ð0:707þ 0:707jÞ 1 ð0
2
66666666666664
X½0
X½1
X½2
X½3
X½4
X½5
X½6
X½7
2
66666666666664
3
77777777777775
¼
xð0Þ þ xð1Þ þ xð2Þ þ xð3Þ þ xð4Þ þ xð5Þ þ xð6Þ þ xð7Þ
xð0Þ þ P1þ ½jxð2Þ þ P2þ ½xð4Þ þ P3þ ½jxð6Þ þ P4
xð0Þ þ ½jxð1Þ þ ½xð2Þ þ ½jxð3Þ þ xð4Þ þ ½xð5Þ þ ½xð6Þ
xð0Þ þ P5þ ½jxð2Þ þ P6þ ½xð4Þ þ P7þ ½jxð6Þ þ P8
xð0Þ þ ½xð1Þ þ xð2Þ þ ½xð3Þ þ xð4Þ þ ½xð5Þ þ xð6Þ þ ½
xð0Þ þ P9þ ½xð2Þ þ P10þ ½xð4Þ þ P11þ ½jxð6Þ þ P12
xð0Þ þ ½jxð1Þ þ ½xð2Þ þ ½jxð3Þ þ xð4Þ þ ½jxð5Þ þ ½xð6Þ
xð0Þ þ P13þ ½jxð2Þ þ P14þ ½xð4Þ þ P15þ ½jxð6Þ þ P16
2
66666666666664
Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020The terms which involved the imaginary terms like jxð1Þ and
jxð3Þ will be obtained as output from the converter when the
input is either x(1) or x(3). Similarly for the terms –x(1) or –x
(2), they will be obtained as output from the converter. The other
terms in the converter are also obtained using the converter.
There are four inputs and so four converters are required for each
term x(0), x(1), x(2) and x(3). The twiddle factor is not needed in
this case because the required terms are obtained from the con-
verter itself. Similarly for an 8 point DFT the matrix is shown
below in Eq. (5), the twiddle factors involved now are integers
other than ±1 and its imaginary form ±1j. So these need to be
generated using a separate converter and then multiplied with
the inputs, cases where the twiddle factor is ±1 or ±1j multiplica-
tion is not required. So this way the number of multiplications is
reduced and the operation also becomes very simple which
involves only conversion, multiplication (not required if twiddle
factor is ±1 or ±1j), and addition.1 1 1
:707þ 0:707jÞ j ð0:707þ 0:707jÞ
1 1 j
707þ 0:707jÞ j ð0:707þ 0:707jÞ
1 1 1
707 0:707jÞ j ð0:707 0:707jÞ
j 1 j
:707 0:707jÞ j ð0:707 0:707jÞ
3
77777777777775

xð0Þ
xð1Þ
xð2Þ
xð3Þ
xð4Þ
xð5Þ
xð6Þ
xð7Þ
2
66666666666664
3
77777777777775
ð6ÞThe conventional algorithm for computing a DFT is given by þ ½jxð7Þ
xð7Þ
þ ½jxð7Þ
3
77777777777775
ð7Þ
ation processor based on complex radix (1 + j) number system, Eng. Sci.
Half 
Adder
b1 a1
S1cx1
Half 
Adder
b2 a2
S2cx2
Full 
Adder
b3 a3
S3cx3
4:2 
Compressor
b4 a4 0
S4cx4
cx5
5:2 
Compressor
b6 a6
S6
cx11 cx12
cx10To part B of Adder
5:2 
Compressor
b10a10
Half 
Adder
S10
cx22
cx10
cx11
cx12
cx13
cx14
cx15
From part A of Adder
5:2 
Compressor
b12a12
Full 
Adder
S12
cx30
cx21
cx20
cx19
5:2 
Compressor
4:2 
Compressor
b13a13
cx27
cx28
cx29
cx23
cx31
cx32
cx33cx24
cx25
cx26
0
cx34
S12 cx35
To part C of Adder 
(b) 
(a) 
5:2 Compressor
b16a16
cx35
cx34
cx33
cx32
cx31
cx50
S16 cx51
cx49
0
cx40
cx39
cx38
cx37
cx36
cx46
cx47
cx48
5:2 Compressor
5:2 Compressor
b19a19
cx50
cx49
cx48
cx47
cx46
5:2 Compressor
cx55
cx54
cx53
cx52
cx51
cx56
cx46
cx47
cx48
Half Adder
cx50
cx51
cx49
cx57
S19
cx57
5:2 Compressor
b20a20
cx52
cx53
cx54
cx55
cx56
5:2 Compressor
cout71
cout72
cx58
cx59
cx60
cx61
cx62
cx57
Half Adder
cx63
S19
cout77
cout73
cout74
cout75
cout76
From  part C of 
Adder
(c) 
Fig. 4. Adder for obtaining the imaginary and negative integers.
6 A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxxwhere P1 = (0.707–0.707j)  x(1), P2 = (0.707–0.707j)  x(3),
P3 = (0.707 + 0.707j)  x(5), P4 = (0.707 + 0.707j)  x(7), P5 =
(0.707–0.707j)  x(1), P6 = (0.707–0.707j)  x(3), P7 = (0.707
+ 0.707j)  x(5), P8 = (0.707 + 0.707j)  x(7), P9 = (0.707Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020+ 0.707j)  x(1), P10 = (0.707 + 0.707j)  x(3), P11 = (0.707–
0.707j)  x(5), P12 = (0.707–0.707j)  x(7), P13 = (0.707
+ 0.707j)  x(1), P14 = (0.707 + 0.707j)  x(3), P15 = (0.707–
0.707j)  x(5), P16 = (0.707–0.707j)  x(7).ation processor based on complex radix (1 + j) number system, Eng. Sci.
 Base (-1+j) Converter 
Input 
vectors 
X (0)
 x(N-(N-1)
Complex 
Adder
 Base (-1+j) Converter 
X (N-1)
Complex 
Adder
 x(N-1)
 Base (-1+j) Converter 
For the whole 
complex number
Twiddle Factor
Complex Mulplier
Complex 
Adder
X (0)
Y[0]
If Twiddle 
factor =1
X (0) -X (0) jX (0) -jX (0) X (N-1) -X (N-1) jX (N-1) -jX (N-1)
WN
Y[N-(N-1)] Y[N-1]
Output 
(a+jB)
Fig. 5. Block diagram for the implementation of DFT processor.
A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxx 75. Results and discussions
5.1. Simulation environment
The design of the converter of decimal value up-to 255 was con-
sidered for testing purpose. The converter and its sub-units were
specified in Verilog, synthesized with Xilinx ISE design suite 14.7.
The inputs are given at a clock frequency of 250 MHz. PropagationTable 2
Synthesized results of the converter as a function of the operand length.
Operand
Length
Speed
Grade
Number of occupied
Slices
Number of Slice
LUTS
1 bit 1 1 1
2 bit 1 3 3
3 bit 1 11 11
4 bit 1 31 31
5 bit 1 50 54
6 bit 1 95 124
7 bit 1 137 230
8 bit 1 150 244
Table 3
Performance parameters like as propagation delay, power consumption and their product
Operand Length Propagation delay (nS) Dynamic powe
1 bit 1.002 0.019
2 bit 1.25 0.9
3 bit 1.357 2.24
4 bit 1.304 3.08
5 bit 1.931 3.96
6 bit 2.191 5.03
7 bit 9.376 6.05
8 bit 9.809 6.45
Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020delay and dynamic power consumption of the converter have been
calculated by NC Launch tool of Cadence. To validate the correct-
ness of the design, more than 500 test cases covering all rounding
modes and exceptions were simulated successfully on the designs.5.2. Results
Synthesized results base on the above mentioned criteria has
been tabulated in Table 2.
The values of delay, power, energy delay product (EDP), and
power delay product (PDP) [23] of different operand length con-
verter are measured and shown in Table 3. The EDP (1021) J-s
and PDP (1012) J are quantitative measure of the efficiency and
a compromise between speed and power dissipation. Input data
were taken in a regular fashion for simulation purpose. For each
transition, the delay is measured from 50% of the input voltage
swing to 50% of the output voltage swing.
The proposed DFT design has also been verified, synthesized
and the delay has also been noted. The power and cost of the
design has been checked in RTL encounter tool in Cadence platform
using 45 nm technology which was generated through the Veriloganalysis of complex radix converter as a function of operand length.
r consumption (mW) EDP (1021) J-s PDP (1012) J
0.019076 0.019038
1.40625 1.125
4.124846 3.03968
5.237281 4.01632
14.76589 7.64676
24.14642 11.02073
531.8517 56.7248
620.5963 63.26805
ation processor based on complex radix (1 + j) number system, Eng. Sci.
Table 4
Cost of Different lengths of DFT in terms of number of modules.
DFT size Cost
Number of (1 + j) converters No. of Multipliers No. of adders
For input vectors For twiddle factors
2 point 2 0 0 4
4 point 4 0 0 16
8 point 8 1 16 64
Table 5
Comparison between expected and generated output for twiddle factors of DFT from complex base (1 + j) converter.
Input Output Percentage
of error(%)
Expected Generated
±0.707 ±0.707 ±0.707 0
±0.707j ±0.707j ±0.707j 0
±0.707 ± 0.707j ±0.707 ± 0.707j ±0.707 ± 0.707j 0
±0.9238 ±0.9238 ±0.9238 0
±0.9238j ±0.9238j ±0.9238j 0
±0.3826 ±0.3826 ±0.3826 0
±0.3826j ±0.3826j ±0.3826j 0
±0.92387 ± 0.38268j 0.9239 + 0.3827j ±0.9239 ± 0.3827j 0
±0.2033j ±0.2033j ±0.2033j 0
±0.11223j ±0.11223j ±0.1122j 0.026
Table 6
Performance parameters and comparison of the proposed DFT processors.
Architecture Parameters
No. of points Propagation Delay (nS) Power (mW) EDP (1018) J-s PDP (109) J
DA [20] 8 point DFT 184 165 5586 30.36
SA [19] 194 178 6699 34.53
CORDIC [21] 179 155 4966 27.75
Proposed 108.54 89 1039 9.65
DA [20] 16 point DFT 385 356 52768 137
SA [19] 432 407 75955 175.8
CORDIC [21] 370 363 49694 134.3
Proposed 253 209 13377 52.8
8 A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxxcode. Table 4 shows the different length DFT processor as a func-
tion of the modules.
%error ¼ expected generated
expected
 100%
The (1 + j) converter showed 100% of accurate for fractional
input up to 4 decimal places and for input up to 5 places the output
generated is rounded off .This makes our circuit more efficient
because no rounding off algorithm or circuit has been employed
in designing the converter. This makes it an efficient floating point
unit and can be used for many floating point applications. The
degree of accuracy was measured in terms of percentage of error
calculated using the formula.
Table 5 shows the comparison of the error for twiddle factor
implementation for DFT computation. From this Table 5 it has been
observed that up to 5 decimal places the error is only 0.026%.5.3. Discussions
Table 6 indicates the performance parameters such as propaga-
tion delay, and dynamic switching power consumptions and their
product analysis proposed DFT processor. Table 6 also contains the
comparison of the implemented 8 point and 16 point DFT proces-
sor with other implementations. For comparison purpose all thePlease cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020implementation methodology have been taken from references
and implemented in same environment.
The implemented methodologies have been compared with
three different methodologies like as distributed arithmetic (DA)
[20] systolic array (SA) [19] and CORDIC [21] based
implementation.
From Table 6 it has been observed that, proposed design is 40%
faster than DA based implementation, 43% faster than SA based
implementation and 39% faster than CORDIC based implementa-
tion respectively.
6. Conclusions
High speed hardware implementation of complex radix (1 + j)
converter has been introduced in this paper. Extensive simulation
results are provided and an application of this converter to discrete
Fourier transformation (DFT) processor has been presented. The
functionality of the DFT processor have been verified in Xilinx
ISE design suite version 14.7 and performance parameters like
propagation delay and dynamic switching power consumption
have been calculated by Virtuoso platform in Cadence. Gate level
implementation of the circuit has been validated for its functional-
ity. Performance parameters like propagation delay and dynamic
switching power consumption has been calculated by Virtuoso
platform in Cadence.ation processor based on complex radix (1 + j) number system, Eng. Sci.
A. Shadap, P. Saha / Engineering Science and Technology, an International Journal xxx (2016) xxx–xxx 9References
[1] D. Knuth, An imaginary number system, Commun. ACM 3 (1960) 245–247.
[2] W. Penney, A numerical system with a negative base, Math. Student J. (1964)
1–2.
[3] W. Penney, A binary system for complex numbers, J. ACM 12 (1965) 247–248.
[4] T. Jamil, N. Holmes, D. Blest, Towards implementation of a binary number
system for complex numbers, Proc. IEEE Southeast Conf. (2000) 268–274.
[5] T. Jamil, The complex binary number system-basic arithmetic made simple,
IEEE Potentials 20 (2002) 39–41.
[6] T. Jamil, An introduction to complex binary number system, Fourth
International Conference on Information and Computing (ICIC), 2011, pp.
229–232.
[7] J. Goode, T. Jamil, D. Callahan, A simple circuit for adding complex numbers,
WSEAS Trans. Inf. Sci. Appl. 1 (2004) 61–66.
[8] T. Jamil, A. Al-Maashari, A. Abdulghani, Design and implementation of a
nibble-size multiplier for (1 + j)-base complex binary numbers, WSEAS Trans.
Circuits Syst. 4 (2005) 1539–1544.
[9] D. Blest, T. Jamil, Division in a binary representation for complex numbers, Int.
J. Math. Educ. Sci. Technol. 34 (2003) 561–574.
[10] T. Jamil, S. Al-Abri, Design of a divider circuit for complex binary numbers, in:
Proc. of the World Congress on Engineering and Computer Science 2010/
International Conference on Circuits and Systems, II, 2010, pp. 832–837.
[11] C.-H. Chang, J. Gu, M. Zhang, Ultra low-voltage low-power CMOS 4–2 and 5–2
compressors for fast arithmetic circuits, IEEE Trans. Circuits Syst.-I 51 (2004)
1985–1987.
[12] W.J. Cooley, A.W.P. Lewis, D.P. Welch, The fast Fourier transform and its
applications, IEEE Trans. Educ. 12 (1969) 27–34.Please cite this article in press as: A. Shadap, P. Saha, Discrete Fourier transform
Tech., Int. J. (2016), http://dx.doi.org/10.1016/j.jestch.2016.08.020[13] A.V. Oppenheim, R.W. Schafer, Discrete-Time Signal Processing, Prentice Hall
Signal Processing, 1999.
[14] H.V. Sorensen, C.S. Burrus, D.L. Jones, A new efficient algorithm for computing
a few DFT points, Proc. IEEE Int. Symp. Circuits Syst. (1988) 1915–1918.
[15] A.M. Despain, Fourier transform computers using CORDIC iterations, IEEE
Trans. Comput. C-23 (1974) 993–1001.
[16] P. Choudhary, A. Karmakar, CORDIC based implementation of Fast Fourier
Transform, Proc. Comput. Commun. Technol. (ICCCT) Conf. (2011) 550–555.
[17] K. Maharatna, A.S. Dhar, S. Banerjee, VLSI array architecture for realization of
DFT, DHT, DCT and DST, Signal Process. 81 (2001) 1813–1822.
[18] N. Sarode, R. Atluri, P.K. Dakhole, Mixed-radix and CORDIC algorithm for
implementation of FFT, Proc. Commun. Signal Process. (ICCSP) Conf. (2015)
1628–1634.
[19] J.A. Beraldin, T. Aboulnasr, W. Steenaart, Efficient one-dimensional systolic
array realization of the discrete Fourier transform, IEEE Trans. Circuits Syst. 36
(1989) 95–100.
[20] W.C. Siu, C.F. Chen, New realisation technique of high-speed discrete Fourier
transform described by distributed arithmetic, IEE Proc. Comput. Digital Tech.
30 (1983) 177–182.
[21] K.M.M. Prabhu, Novel CORDIC-based systolic arrays for the DFT and the DHT,
High Perform. Comput. Inf. Superhighway (1997) 547–551.
[22] O.V. Kontkanen, M. Niskanen, T.I. Hukka, T.T. Rantalab, Electronic structure of
p-type perylene monoimide-based donor–acceptor dyes on the nickel oxide
(100) surface: a DFT approach, Phys. Chem. Chem. Phys. (2016) 14382–14389.
[23] M. Jhamb Garima, H. Lohani, Design, implementation and performance
comparison of multiplier topologies in power-delay space, Eng. Sci. Technol.
Int. J. 19 (2016) 355–363.ation processor based on complex radix (1 + j) number system, Eng. Sci.
