Performance of Linear Block Codes Concatenated with Differential PSK by Lo, V. & Martin, P.A.
782 IEEE COMMUNICATIONS LETTERS, VOL. 12, NO. 10, OCTOBER 2008
Performance of Linear Block Codes Concatenated with Differential PSK
Victor Lo, Student Member, IEEE, and Philippa A. Martin, Senior Member, IEEE
Abstract—In this letter we investigate the bit and frame
error rate performance of various linear block codes when
concatenated with a differential phase shift keying modulator.
The codes considered include single parity check, Hamming and
product codes. We find block codes which significantly improve
the frame error rate performance over previous results. An EXIT
chart analysis is included.
Index Terms—Accumulator, Hamming code, product code.
I. INTRODUCTION
THE serial concatenation of a linear block code with arate-1 recursive convolutional code (or accumulator) has
been shown to provide good performance in additive white
Gaussian noise (AWGN) channels [3]. Much attention has
been focused on the choice of linear block code. Proposed
codes include repetition [3], concatenated single parity check
(SPC) [9], Hamming [6], [4] and extended Bose Chaudhuri
Hocquenghem (eBCH) [8] codes. More recently, researchers
have looked at replacing the accumulator with a (rate-1) M -
ary differential phase shift keying (M -DPSK) modulator [5],
[10], which allows reasonable performance for an unknown
phase. SPC codes [5] and double parity check (DPC) codes
[10] have been proposed for use with the DPSK modulator.
They allow good bit error rate (BER) performance to be
achieved in the waterfall region and have error floors below
10−6. However, we have found the frame error rate (FER)
performance starts to floor below 10−3.
In this letter we investigate the BER and FER performance
of various linear block codes concatenated with a DPSK
modulator. Our aim is to significantly improve the FER
performance compared to [5], [10]. The cost of the lower error
floor is a slight loss in BER and/ or FER performance in the
waterfall region or a loss in code rate.
II. SYSTEM DESCRIPTION
The system under consideration consists of an encoder for a
(n, k, dmin) linear block code serially concatenated with a M -
DPSK encoder (with M = 8), where n is the code length, k is
the number of data bits and dmin is the minimum Hamming
distance. A bit interleaver of length N , denoted π, separates
the two encoders as shown in Fig. 1(a). The N bits from
the interleaver result in N/m M -DPSK symbols, where m =
log2(M). Note that N is chosen such that N = αm and
N = βn, where α and β are integers. The sequence of N/m
M -DPSK symbols defines a frame.
Manuscript received June 30, 2008. The associate editor coordinating the
review of this letter and approving it for publication was M. Dohler.
The authors are with the Department of Electrical and Computer En-
gineering, University of Canterbury, Christchurch, New Zealand (e-mail:
vll10@student.canterbury.ac.nz, p.martin@elec.canterbury.ac.nz).
Digital Object Identifier 10.1109/LCOMM.2008.081010
8-PSKRate -1 
Accumulator
Delay
+
Linear
Block
Code
xt
Data mod 8 000
001
010
011
100
101 111110
+
yt
wt
mod 8
vt
8-DPSK Modulator
(a) Encoder.
n k dmin Code Recc
16 9 4 PC (4, 3, 2)2 0.563
15 9 3 PC (4, 3, 2)2 no PoP 0.6
15 10
9 6 2 LPC 0.667
6 4
3 2 2 SPC 0.667
16 11 4 extended Hamming 0.6875
15 11 3 Hamming 0.733
(b) Linear block codes considered.
Block code decoder 
(replication decoding on 
the dual code)
Calc
channel 
metrics
Bit to 8-
symbol
8-DPSK
decoder 
(BCJR)
8-symbol 
to bit +
-
ch
qmt?? dpsk
qmt??)|( ytvP ?? qmt?
i?
?,lbc
qmt?? lbci?
)( t
lbc vP
ty
(c) Decoder.
Fig. 1. Encoder, component codes and decoder.
An AWGN channel is considered. The received signal is
given by yt = xt + wt, where xt is the tth transmitted M -
DPSK symbol and wt is the tth complex AWGN sample with
variance N0/2 = (2mRecc10SNR/10)−1 in each dimension,
where Recc is the code rate of the block code and SNR is
the signal to noise ratio in Decibels (dB). Results in [5] show
only a slight loss in performance when there is an unknown
phase. Therefore, as in [10] we do not simulate an unknown
phase.
A. Linear Block Codes
We now discuss the linear block codes considered (sum-
marized in Fig. 1(b)). We are primarily interested in rate
Recc = 2/3 codes. The code is denoted C and a codeword is
denoted c = [u1, · · · , uk, p1, · · · , pn−k], where ui is the ith
data bit and pi is the ith parity bit. For comparison purposes
we consider the (3, 2, 2) SPC code discussed in [5]. In [10]
two types of DPC codes were proposed. Only the DPC-I codes
offer rates greater than Recc = 1/2. The (3, 2, 2) SPC code
is the highest rate DPC-I code with Recc = 2/3. The parity
bits are defined by pi = ui ⊕ ui+1 for 1 ≤ i ≤ k − 1. The
EXIT chart [11] for the (3, 2, 2) SPC code is shown in Fig. 2.
1089-7798/08$25.00 c© 2008 IEEE
Authorized licensed use limited to: University of Canterbury. Downloaded on June 14,2010 at 09:22:02 UTC from IEEE Xplore.  Restrictions apply. 
LO and MARTIN: PERFORMANCE OF LINEAR BLOCK CODES CONCATENATED WITH DIFFERENTIAL PSK 783
0 0.2 0.4 0.6 0.8 1
0
0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1
Linear Input, Differential Output
Li
ne
ar
 O
ut
pu
t, 
Di
ffe
re
nt
ia
l I
np
ut
 
 
SPC (3,2) R=0.66
LPC (9,6) R=0.66
Hamming (15,11) R=0.73
Hamming(16,11) R=0.68
PC (15,9) R=0.6
PC (16,9) R=0.56
Differential SNR=4.0
Differential SNR=4.3
Fig. 2. EXIT charts for various linear block codes.
It has a bottleneck at high mutual information impairing final
convergence, which is expected to adversely impact the high
SNR FER.
We developed the following Recc = 2/3, dmin = 2 linked
parity check (LPC) codes by linking several (3, 2, 2) SPC
codes together. This is done by adding ones in the positions
immediately above and below each pair of ones in the parity
check section of the generator matrix. Linking three codes
results in a (9, 6, 2) LPC code with generator matrix
G=
⎡
⎢⎢⎢⎢⎢⎢⎣
1 0 0 0 0 0 1 0 1
0 1 0 0 0 0 1 1 0
0 0 1 0 0 0 1 1 0
0 0 0 1 0 0 0 1 1
0 0 0 0 1 0 0 1 1
0 0 0 0 0 1 1 0 1
⎤
⎥⎥⎥⎥⎥⎥⎦
. (1)
The parity bits are defined by pi = u2i−2⊕u2i−1⊕u2i⊕u2i+1
for i = 1, · · · , k/2 (k must be even), where uk+1 = u1 and
u0 = uk. These codes move the bottleneck in Fig. 2 to lower
mutual information, which should improve final convergence
at the cost of waterfall region performance.
The M -DPSK modulator was also concatenated with a
(4, 3, 2)2 = (16, 9, 4) product code (PC) and a (15,9,3)
PC without the parity-on-parity (PoP) bit. In addition, the
(15, 11, 3) Hamming code and the (16, 11, 4) extended Ham-
ming code were considered. These component codes have
higher values of dmin, which should result in lower error
floors. Fig. 2 shows the higher rate Hamming codes require
larger SNR to converge due to a bottleneck at low mutual
information. The PCs give excellent performance for the entire
decoding process, but have the lowest rates.
A mix of codewords from different codes can be used [7]
to modify the code rate and performance. For example, by
creating N/2 bits using the (15, 9, 3) PC and N/2 bits using
the (15, 11, 3) Hamming code the overall rate is Recc = 2/3.
The M -DPSK encoder uses natural mapping [5] of bits to
symbols for the Hamming and PCs. The alternate mapping
proposed in [5], [10] was used for the SPC and LPC codes.
B. Decoder
The concatenated system is decoded using iterative decod-
ing as shown in Fig. 1(c). The differential (DPSK) code is
decoded using the BCJR algorithm [1] and the linear block
code is decoded using replication decoding [2]. The input and
output metrics for these algorithms are briefly described below.
See [5], [1], [2] for more details.
The channel log likelihood ratio (LLR) for the (mt + q)th
transmitted bit is given by [5], [10]
Λchmt+q =log
P (yt|gmt+q = 0)
P (yt|gmt+q = 1) =log
∑
xˆt|gmt+q=0
P (yt|xˆt)
∑
xˆt|gmt+q=1
P (yt|xˆt)
,
(2)
where q = 0, 1, · · · ,m− 1, gmt+q is the qth bit labelling the
hypothesized constellation point at symbol time t, xˆt, and
p(yt|xˆt) ∝ e−|yt−xˆt|2/N0 . (3)
The inputs to the M -DPSK BCJR decoder are the channel
symbol probability densities of (3) and the extrinsic symbol
probabilities from the linear block code’s decoder for the tth
symbol, P lbc(vt). Initially, P lbc(vt) = 1/M is used for all M
possible symbols.
The M -DPSK symbol probabilities from the BCJR decoder,
P (vt|y), are converted to LLR bit probabilities using
Λdpskmt+q =log
P (vt|gmt+q = 0)
P (vt|gmt+q = 1) =log
∑
vˆt|gmt+q=0P (vˆt|y)∑
vˆt|gmt+q=1P (vˆt|y)
,
(4)
where q = 0, 1, · · · ,m−1 and y is the received signal vector.
The extrinsic bit information from the BCJR decoder is
λπmt+q = Λ
dpsk
mt+q − Λlbc,πmt+q, (5)
where Λlbc,πmt+q is the interleaved extrinsic bit LLR from the
block code’s decoder. Deinterleaving λπmt+q gives λi.
Replication decoding [2] is used to decode the linear block
code, C. The resulting (uninterleaved) extrinsic LLR for the
ith bit is given by Λlbci =
log
⎛
⎜⎜⎜⎜⎜⎜⎜⎜⎜⎜⎝
1+
∑
c′∈{c′}i0
∏
j∈Jc′ ,
i = j
tanh
(
λj
2
)
+
∑
c′∈{c′}i1
∏
j∈Jc′ ,
i = j
tanh
(
λj
2
)
1+
∑
c′∈{c′}i0
∏
j∈Jc′ ,
i = j
tanh
(
λj
2
)
−
∑
c′∈{c′}i1
∏
j∈Jc′ ,
i = j
tanh
(
λj
2
)
⎞
⎟⎟⎟⎟⎟⎟⎟⎟⎟⎟⎠
,
(6)
where c′ is a word in the dual code C ′, J ′c is the set of indices
j = 0, 1, ..., n− 1 corresponding to the positions of 1’s in c′,
and {c′}i0 and {c′}i1 are the sets of codewords having 0 and
1 in their ith positions, respectively.
The probabilities for the (mt + q)th bit, cmt+q, after
decoding the block code are calculated using
P (cmt+q =0)=
Λlbc,πmt+q
1+Λlbc,πmt+q
, P (cmt+q =1)=
1
1+Λlbc,πmt+q
. (7)
Authorized licensed use limited to: University of Canterbury. Downloaded on June 14,2010 at 09:22:02 UTC from IEEE Xplore.  Restrictions apply. 
784 IEEE COMMUNICATIONS LETTERS, VOL. 12, NO. 10, OCTOBER 2008
3 3.5 4 4.5 5 5.5 6 6.5
10−10
10−8
10−6
10−4
10−2
100
54
275
55
70
53
40 40
36
Eb/N0 (dB)
BE
R
 
 
Hamming (15,11)
Hamming (16,11)
PA (15,9)
PA (16,9)
LPC (15,10)
SPC (3,2)
LPC (6,4)
LPC (9,6)
Mix (15,10)
Mix (16,10)
Howard (3,2)
Fig. 3. BER performance for various linear block codes.
3 3.5 4 4.5 5 5.5 6 6.5
10−5
10−4
10−3
10−2
10−1
100
54
27
5
55
70
53
40
40
36
Eb/N0 (dB)
FE
R
 
 
Hamming (15,11)
Hamming (16,11)
PC (15,9)
PC (16,9)
LPC (15,10)
SPC (3,2)
LPC (6,4)
LPC (9,6)
Mix (15,10)
Mix (16,10)
Fig. 4. FER performance for various linear block codes.
The associated symbol probabilities are calculated using
P lbc(vt = Xd) =
m∏
q=1
P (cmt+q = Cdq ), (8)
where d = 0, · · · ,M−1, Xd is the dth symbol in the constel-
lation, labelled by bits (Cd1 , · · · , Cdm). These probabilities are
used to calculate the soft input to the M -DPSK BCJR decoder.
Decoding continues until convergence or a maximum number
of iterations is reached. The final decision for the ith bit is
the hard decision on Λlbci + λi.
III. SIMULATION RESULTS
Fig. 3 and Fig. 4 show the BER and FER performance1 of
the concatenated codes, respectively, where Eb is the data bit
energy. We used an S-random bit interleaver with S = 9 and
N ≈ 15000 bits2. The (3, 2) SPC code results of Howard et.
1The number of frame errors is stated if less than 100.
2For n = 3, 6, 15 we use N = 15000, for n = 9 we use N = 15003
and for n = 16 we use N = 15024 except for the mixed (16, 11)/ (16, 9)
code which uses N = 14976.
al. [5] vary slightly from our own. This is most likely due to
the use of a different interleaver. The LPC codes can lower the
error floor compared to the SPC code at the cost of waterfall
performance.
As can be seen the PCs offer the best performance, showing
no error floor at a FER of 10−4. This is at the cost of code rate.
Due to a larger dmin, the Hamming codes are also expected
to have a low FER error floor [6]. Due in part to their higher
rate, they require higher SNR to decode.
Fig. 3 and Fig. 4 show mixed codes, where an equal number
of PC and (extended) Hamming codewords are used giving
overall rate Recc = 0.625 for n = 16 and Recc = 2/3 for
n = 15. This provides a good compromise between waterfall
performance, error floor performance and rate.
IV. CONCLUSIONS
We investigated the use of various linear block codes con-
catenated with an 8-DPSK modulator. We have significantly
reduced the FER error floor. In particular, the PCs resulted
in a significantly lower error floor at the cost of rate and
decoding complexity. The codes presented allow tradeoffs
between code rate, decoding complexity, waterfall (low SNR)
and error floor (high SNR) performance. Using a mixture
of (extended) Hamming codes and PCs provided a good
compromise between these factors.
REFERENCES
[1] L. R. Bahl, J. Cocke, F. Jelinek, and J. Raviv, “Optimal decoding of
linear codes for minimizing symbol error rate,” IEEE Trans. Inform.
Theory, pp. 284-287, Mar. 1974.
[2] G. Battail, M. C. Decouvelaere, and P. Godlewski, “Replication decod-
ing,” IEEE Trans. Inform. Theory, vol. 25, no. 3, pp. 332-345, May
1979.
[3] D. Divsalar, H. Jin, and R. J. McEliece, “Coding theorems for ‘turbo-
like’ codes,” in Proc. 36th Allerton Conf., pp. 201-210, Monticello, IL,
Sept. 1998.
[4] D. Divsalar and S. Dolinar, “Concatenation of Hamming codes and ac-
cumulator codes with high-order modulations for high-speed decoding,”
IPN Progress Report, 42-156, Feb. 15 2004.
[5] S. L. Howard and C. Schlegel, “Differential turbo-coded modulation
with APP channel estimation,” IEEE Trans. Commun., vol. 54, no. 8,
pp. 1397-1406, 2006.
[6] M. Isaka and M. Fossorier, “High-rate serially concatenated coding with
extended Hamming codes,” IEEE Commun. Lett., vol. 9, no. 2, pp. 160-
162, Feb. 2005.
[7] M. Isaka, “High-rate serially concatenated codes using Hamming codes,”
in Proc. ICC, pp. 637-641, 2005.
[8] M. Isaka, P. A. Martin, and M. P. C. Fossorier, “Design of high-
rate serially concatenated codes with low error floor,” IEICE Trans.
Fundamentals Electron., Commun., Computer Sciences, vol. E90-A, no.
9, pp. 1754-1762, Sept. 2007.
[9] J. Li, K. R. Narayanan, and C. N. Georghiades, “Product accumulate
codes: a class of codes with near-capacity performance and low decoding
complexity,” IEEE Trans. Inform. Theory, vol. 50, no. 1, pp. 31-46, Jan.
2004.
[10] J. Mitra and L. Lampe, “Simple concatenated codes using differential
PSK,” in Proc. Globecom, 2006.
[11] S. ten Brink, “Convergence behavior of iteratively decoded parallel
concatenated codes,” IEEE Trans. Commun., vol. 49, no. 10, pp. 1727-
1737, Oct. 2001.
Authorized licensed use limited to: University of Canterbury. Downloaded on June 14,2010 at 09:22:02 UTC from IEEE Xplore.  Restrictions apply. 
