A Soft Cancellation Decoder for Parity-Check Polar Codes by Tong, Jiajie et al.
ar
X
iv
:2
00
3.
08
64
0v
2 
 [c
s.I
T]
  2
 Ju
l 2
02
0
A Soft Cancellation Decoder for Parity-Check Polar
Codes
Jiajie Tong, Huazi Zhang, Xianbin Wang, Shengchen Dai, Rong Li, Jun Wang
Huawei Technologies Co. Ltd.
Email: {tongjiajie, zhanghuazi, wangxianbin1, daishengchen, lirongone.li, justin.wangjun}@huawei.com
Abstract—Polar codes has been selected as the channel coding
scheme for 5G new radio (NR) control channel. Specifically, a
special type of parity-check polar (PC-Polar) codes was adopted
in uplink control information (UCI). In this paper, we propose
a parity-check soft-cancellation (PC-SCAN) algorithm and its
simplified version to decode PC-Polar codes. The potential
benefits are two-fold. First, PC-SCAN can provide soft output
for PC-Polar codes, which is essential for advanced turbo
receivers. Second, the decoding performance is better than that
of successive cancellation (SC). This is due to the fact that parity-
check constraints can be exploited by PC-SCAN to enhance the
reliability of other information bits over the iterations. Moreover,
we describe a cyclic-shift-register (CSR) based implementation
“CSR-SCAN” to reduce both hardware cost and latency with
minimum performance loss.
Index Terms—Polar codes, Soft cancellation, Parity Check, PC-
Polar, PC-SCAN, CSR-SCAN.
I. INTRODUCTION
A. Background and related works
Polar codes, proposed by Arikan [1], has been selected as
the channel coding scheme for 5G NR control channel. Polar
codes with SC decoding is proved to achieve channel capacity
at infinite length. To improve error-correction performance
at short or moderate length, SC-list (SCL) decoding [2]
is proposed by keeping L codeword candidates during the
sequential decoding process. In practice, cyclic redundancy
check (CRC) [3], parity-check (PC) [4] and convolutional code
(CC) [5] bits can be inserted as outer codes to further improve
the performance. They can be unified as pre-transformed polar
codes [6].
Among the pre-transformed polar codes, PC-Polar codes ex-
hibits low-complexity, flexibility and robust performance gain
under fine-granularity evaluations [4]. A simplified version
of PC-Polar [7], [8] is adopted by 3GPP [9] to enhance the
performance of 5G UCI channel. The PC bit values are set
to linear combinations of some preceding information bits,
implemented by simple cyclic shift registers. Such a simple
pre-transformation, like CA-Polar and PAC-Polar, can improve
the code minimum distance [6]. It is shown in [4] that PC-Polar
outperforms CA-Polar by 0.2 ∼ 1.0dB under SCL decoders
with L = 8.
B. Motivation and Contribution
The problem with SC and SCL decoders is they cannot
output soft decoding results. The latter is essential for many
applications such as decoding of concatenated codes [10] and
advanced turbo receivers [11] (e.g., in multiple-input multiple-
output and non-orthogonal multiple access). To address this
issue, a soft-cancellation (SCAN) decoding [12] is proposed
to both provide soft output and improve bit error rate (BER)
performance. If multiple iterations are allowed, the frame error
rate (FER) performance can also improve over SC decoding.
Unfortunately, current SCAN algorithms do not support PC-
Polar codes, or any pre-transformed polar codes.
In this paper, we propose a parity-check soft-cancellation
(PC-SCAN) algorithm and its simplified version to decode
PC-Polar codes. This is the first attempt to implement a
SCAN decoder on PC-polar codes. Our algorithm incorporates
an additional layer in factor graph to account for the PC
constraints, and specifies a scheduling method to update the
soft information. Simulation results show better BER and FER
(with more than one iterations). An example of N = 64,K =
32 polar codes is given in Fig. 5.
PC-SCAN requires an additional module on top of SCAN.
The module updates the log-likelihood ratio (LLR) of the
information/PC bits. At the first glance, the updating rules
are similar to those in LDPC codes. However, they turn
out to be quite different due to the sequential scheduling of
SCAN decoders. Hence, we propose novel LLR updating rules
to address this change. Furthermore, to facilitate hardware-
friendly implementation, we propose a simplified version
of PC-SCAN named CSR-SCAN. The simplification mainly
exploits the regular structure of PC-Polar. We show that the
performance loss is minimum (< 0.1dB in FER) while the
additional hardware area beyond the original SCAN decoder
is very small.
II. TREE REPRESENTATION OF SOFT CANCELLATION
In this section, we review the basic methods of SCAN
to decode the basic Polar codes. The SCAN decoder has
a recursive architecture that is similar to the SC decoder.
Therefore, it can be represented as a binary tree traversal [13],
as shown in Fig. 1(a). Following the notations in [13], a node
v in a tree is directly connected to a parent node pv, left child
node vl and right child node vr, respectively
1. The stage of
a node v is defined by the number of edges between node v
and its nearest leaf node. All leaf nodes are at stage s = 0.
The set of nodes of the subtree rooted at node v is denoted by
1A leaf node vleaf has no child node, and a root node vroot has no parent
node.
Stage: s=3
s=2
s=1
s=0
i=0     1     2    3     4     5     6    7
??? ??? ??? ???
?? ??
?? ??
?
??
(a) (b)
Fig. 1. (a) decoding architecture as a binary tree; (b) node v received/response
information
Vv . Thus Vroot denotes the full binary decoding tree. The set
of all leaf nodes is denoted by U , the index of a leaf u [13]
is denoted by l(u).
The set of all information bits are denoted by I and that of
all frozen bits by Ic. We denote the information bit indices
among the decoding tree.
I = {l(u), u ∈ I}
Denote the frozen bit indices among the decoding tree by
Ic = {l(u), u ∈ Ic}
Similar to [13], knowledge about decoded bits, e.g., in the
form of log-likelihood ratio (LLR), is exchanged between
neighboring nodes. The root node vroot receives LLRs αroot
directly from the channel output. As illustrated in Fig. 1(b),
node v receives an LLR vector αv from its parent pv, and feeds
back an LLR vector βv to its parent pv. The difference from
[13] is that here βv is no longer the hard decisions (partial
sums), but soft information. It is called response LLR [12]. If
node v is at stage s, vectors αv and βv both have 2
s elements,
respectively denoted by αiv and β
i
v, i ∈ [0, 2
s − 1].
According [12], a node v at stage s passes information to
its child nodes αvl and αvr as follows
2:{
αivl = α
i
v ⊞ (β
i
vr
+ αi+2
s−1
v ), i ∈
{
0, · · · , 2s−1 − 1
}
αivr = (α
i
v ⊞ β
i
vl
) + αi+2
s−1
v , i ∈
{
0, · · · , 2s−1 − 1
}
(1)
The soft information feedback to its parent node is as
follows{
βiv = β
i
vl
⊞ (αi+2
s−1
v + β
i
vr
), i ∈
{
0, · · · , 2s−1 − 1
}
βi+2
s−1
v = (β
i
vl
⊞ αiv) + β
i
vr
, i ∈
{
0, · · · , 2s−1 − 1
}
(2)
Unlike SC, the SCAN decoder runs iteratively, which means
binary tree can be traversed several rounds. In the first itera-
tion, we should initialize αroot as the channel output LLRs,
and βv, v ∈ Vroot \ Uroot as all zeros. During the course of
decoding, the vector βv will be updated by (2). The algorithm
terminates after a maximum of Tmax iterations.
The soft messages βv, v ∈ Uroot at leaf nodes do not change
over time. They are always either +∞ (for zero-valued frozen
bits) or 0 (for information bits).
2In [12], there is a bit-revisal step before forwarding each LLR vector. But
this step is unnecessary [14] and is removed in many other recent works.
III. PARITY-CHECK POLAR CODES
For PC-Polar codes, there are three types of bits, i.e.,
information bits, frozen bits and PC bits. We address three
PC-Polar schemes in this paper:
• NR(new radio)-PC-Polar as described in “5G; NR; Mul-
tiplexing and channel coding” [9], where there are three
PC bits.
• FC(full check)-PC-Polar as described in [4], where all
non-information bits are treated as PC bits. This gives
the best performance.
• MC(min-check)-PC-Polar as described in [7], where all
non-information bits with specific row weight(s) are
selected as PC bits. The row weight can be wmin, the
minimum row weight in the information set, or 2×wmin,
the second lowest row weight in the information set.
The only difference among NR-PC-Polar, FC-PC-Polar and
MC-PC-Polar is the PC bits number/positions. As said, NR-
PC-Polar has a fixed number of PC bits. But for MC-PC-
Polar, the PC bits number is controlled by a coefficient A3 [4].
The PC bit values are linear combinations of some preceding
information bits. Such a pre-coding, or pre-transform, can
improve the code minimum distance [6].
Algorithm 1 shows the encoding steps of a length-N PC-
Polar code, where N = 2n is the mother code length.
Comparing with the original Polar encoder, it only has an
additional step 4.
Algorithm 1 Parity-check Polar encoding [4]
(1) Generate the information/frozen/PC bits positions.
(2) Generate an all-zero sequence of length N .
(3) Fill in the transmitted bit values at information positions,
resulting in sequence s.
(4) PC pre-coding, get the new sequence q.
(5) Polar encoding, q×G, where G is a N ×N Kronecker
matrix.
In [4], a very simple way of PC pre-coding is proposed.
The value of a PC bit u ∈ P is the sum of all its preceding
information bits with a spacing of L (or multiples of L). The
PC constraints can be formulated as
s[i] =
∑
j<i
(i−j)%L=0
s[j], (3)
where i is the index of the PC bit, and j denotes the indices
of all preceding information bits checked by the PC bit.
The PC pre-coding can be easily implemented by cyclic
shift registers σ of length L. The circuit is very simple, as
shown in Fig. 2, where a register state is updated by
σx = σx ⊕ s[i], x = i%L, i < N. (4)
Traditionally, its decoder is modified from SC or SCL by
adding a PC bit calculation module. During path extension
3The notation of the coefficient is originally α in [4]. To avoid conflict
with the soft input α in this paper, we use A to rename the coefficient.
?? ?? ?? ?????
?
???????????
????????????????????????????
??????????????????????????
?
?
????????????????????????????
?
?
????????????????????????????????????
???????????????????????????????????
??????????????????????????????
?
?
?
?????
??????????
? ? ? ????
????
?????????? ??????????????????? ????????
???
?
Fig. 2. PC pre-coding circuit.
and pruning, only the paths that satisfy the PC constraints are
kept. The process resembles hard decoding where the PC bit
values serve as “hard constraints” to select the valid paths.
IV. PARITY CHECK SOFT CANCELLATION
In this section, we introduce a novel soft cancellation
decoding algorithm, namely PC-SCAN, that supports PC-Polar
codes4. Unlike SC/SCL decoders, the proposed method treats
PC bits as “soft constraints” to process the soft information
generated by SCAN. Consequently, PC-SCAN can generate
the soft outputs.
We still use I and F to denote the set of information bits
and frozen bits, respectively. The set of PC bits is denoted by
P . The frozen and PC bit indices among the decoding tree’s
leaf nodes U are respectively denoted by
F = {l(u), u ∈ F} ,
P = {l(u), u ∈ P} .
By definition, F ∪ P = Ic and Fv ∪ Pv = I
c
v .
According to (3), only bit positions with a spacing of L
(or multiples of L) will engage in the same PC constraint.
Based on this observation, we can separate the leaf nodes
in I and P into L independent groups. Specifically, the i-
th information/PC bit belongs to the i%L-th group, where
the group index takes value in {0, 1, · · · , L − 1}. Since the
nodes in the different groups are independent in terms of PC
constraints, we call each group a “parity-check chain”.
To facilitate description, we specify the following notations.
Denote by I(u) the set of all information bits checked by a
PC bits u ∈ P . The bit indices in a “checked information set”
I(u), u ∈ P is denoted by
I(u) = {l(u′), u′ ∈ I(u)} , for u ∈ P .
The union set of all checked information bits is denoted by
I˜ =
⋃
u∈P
I(u). (5)
The bit indices in I˜ are denoted by
I˜ =
{
l(u), u ∈ I˜
}
.
4In principle, the method also supports any pre-transformed polar codes [6],
while our focus is on PC-Polar codes [4] due to its simplicity and performance.
The remaining set of all unchecked information bits is
denoted by
I˜c = I \ I˜
The bit indices in I˜c are denoted by
I˜c =
{
l(u), u ∈ I˜c
}
.
Similarly, denote by P(u) the set of all PC bits checking
an information bits u ∈ I˜. The bit indices in a “checking PC
set” P(u), u ∈ I˜ is denoted by
P (u) = {l(u′), u′ ∈ P(u)} , for u ∈ I˜.
The PC-SCAN algorithm first constructs a binary-tree in the
recursive manner as in the original SCAN decoder, and then
traverse the tree. It can be divided into two parts:
• Traverse the tree and apply (1) and (2) to calculate
the input/output soft information of each node v when
entering/leaving the subtree Vv. When the tree traversal
reaches a leaf node u, such that u /∈ {P ∪ I˜}, we directly
obtain the soft feedback β as follows
βu =∞, for u ∈ F . (6)
βu = 0, for u ∈ I˜
c. (7)
• The second part calculates the soft feedback β at leaf
nodes such that u ∈ {P ∪ I˜}. These are the informa-
tion/PC bits that engage in PC constraints. The L “parity-
check chains” are modelled by L tanner graphs represent-
ing the parity-check relationships between information
bits and PC bits. As will be described shortly, we use
leaf nodes input αu to calculate the soft feedback βu.
Fig. 3 shows an example of the connections between the
original SCAN decoding tree and parity check chains. In this
example, the number of information bits (including CRC bits)
is 32 and the code length is 64. Specifically, the reliability
order is determined by polarization weight (PW) [15], and the
number and positions of PC bits are determined as in FC-PC-
Polar [4]. In the interest of space, the leaf nodes before the first
information bit and after the last parity check bit are omitted,
as they do not affect parity-check decoding. The length of
cyclic shift registers is L = 5, resulting in five independent
parity-check chains.
The set of bits in parity-check chain-0 is denoted by
U(0) = {u, u ∈ U and l(u)%5 = 0}
According the Fig. 3, the indices of u ∈ U(0) are grouped as
follows 

{0, 5, 10} ⊂ F
{20, 35, 40, 50} ⊂ P
{15, 25, 30, 45} ⊂ I˜
{55, 60} ⊂ I˜c
The PC constraints are illustrated by a tanner graph is
plotted in Fig. 4(a). It includes all the checked information
bits and PC bits in the PC chain-0 and model their parity-
check relationship. All the checked information bits and PC
s=3
s=2
s=1
s=0
s=5
s=4
Stage: s=6
...
PC Chain-0
PC Chain-1
PC Chain-2
PC Chain-3
PC Chain-4
Decoder Tree
Parity Check 
None-Leaf Node Information Leaf Frozen Leaf Parity Check Leaf
Stage: 
... ...
PC Chain
PC Chain
PC Chain
PC Chain
PC Chain
Decoder Tree
Parity Check 
None Leaf Node Information Node Frozen Node Parity Check Node
...
All Info LeafAll Frozen Leaf
Fig. 3. Connections between SC decoding tree and parity check constraints
C-nodes
V-nodes
15 20 25 30 35 40 45 50
f0 f1 f2 f3
Indices
?
f1
Update check nodes
f0 f1 f2 f3
Update variable node
????
??? ???
25 30 3515
? ? ?
15
Fig. 4. (a) The tanner graph of PC Chain-0; (b) Check nodes update (input
α); (c) Cariable node update (output β).
bits are regarded as variable nodes in the tanner graph. The
number of check nodes is equal to the number of PC bits in
this PC-chain, as each check node represents a PC constraint.
In this example, there are eight variable nodes and four check
nodes.
Fig. 4(b) and Fig. 4(c) show how to update the variable
nodes’ soft output β with the soft input α from the SCAN
decoder.
For a PC bit u ∈ P , its soft output β is calculated by
βu = λP×(αu′0 ⊞ αu′1 ⊞ · · ·⊞ αu′N ), (8)
where {u′0, · · · , u
′
N} = I(u) for u ∈ P .
For an information bit u ∈ I˜ , its soft output β is
βu =
∑
u′∈P(u)
ηu′ , for u ∈ I˜, (9)
where ηu′ is contributed by its neighboring PC bit u
′
ηu′ = λI˜×(αu′ ⊞ αu′′0 ⊞ · · ·αu′′N ),
where {u′′0 , · · · , u
′′
N} = I(u
′) \ u for u′ ∈ P(u).
Note that λP and λI˜ are non-negative damping factors,
which vary over code lengths and iterations. They are usually
determined empirically.
In practice, the “box-plus” operation ⊞ is implemented in
an approximate but hardware-friendly way
x⊞ y ≈ f(x, y) = (10)
(1 − 2(sign(x)⊕ sign(y)))×min(abs(x), abs(y)),
where sign(x) is the sign of x, abs(x) is the absolute value
of x, and min is minimum of input variables.
The f -function can also take multiple inputs
x1 ⊞ · · ·⊞xn ≈ f(x1, · · · , xn) =
(1− 2(sign(x1)⊕ · · · ⊕ sign(xn)))
×min(abs(x1), · · · , abs(xn)).
With the above simplification, (8) can be rewritten as
βu = λP × f(αu′0 , αu′1 , ..., αu′N ) |{u′0...u′N}=I(u) (11)
Likewise, (9) can be rewritten as
βu =
∑
u′∈P(u)
λI˜ × f(αu′ , αu′′0 , ..., αu′′N ) |{u′′0 ,...u′′N}=I(u′)\u
(12)
PC-SCAN follows a special scheduling that sequentially
updates the soft information of leaf nodes. Specifically, the
Es/N0 (dB)
2 2.5 3 3.5 4 4.5 5 5.5 6
FE
R
/B
ER
10-6
10-5
10-4
10-3
10-2
10-1
100
K=32
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
Fig. 5. Performance of FC-PC-Polar with N = 64, K = 32,A = 0.5.
soft input α from SCAN are obtained successively over time.
When updating the soft output β of an information/PC bit, the
associated soft input α from succeeding bits are not available.
This is in contrast to belief propagation (BP) algorithms which
can simultaneously update all leaf nodes.
For PC-SCAN, a detailed description of scheduling and
node updating operations is described in Algorithm 2.
Algorithm 2 Parity-check Soft Cancellation (PC-SCAN)
Input: I,F ,P , αroot, Tmax
Output: β
Derive I˜ according to (5);
soft cancellation iterations
for (t = 0; t < Tmax; t = t+ 1)
Call recursive decoder(vroot, αroot);
recursive decoder(v, αv)
Calculate αvl , αvr according to (1);
if (v /∈ U )
Call recursive decoder(vl, αvl);
Call recursive decoder(vr, αvr );
else
Call leaf decoder(ul, αul );
Call leaf decoder(ur, αur );
Calculate βv according to (2);
leaf decoder(u, αu)
if (u ∈ P)
Calculate βu according to (11);
else if (u ∈ I˜)
Calculate βu according to (12);
else if (u ∈ F )
βu =∞;
else
βu = 0;
The FER and BER performances under PC-SCAN is shown
in Fig. 5, in which the code construction is given in Fig. 3.
In this case, the FER of PC-SCAN is similar to that of SC
after the first iteration, but the BER is better by 0.1dB. After a
few iterations, the PC-SCAN decoder outperforms SC on both
FER and BER. Besides, PC-SCAN can output soft decoding
results.
V. CYCLIC-SHIFT-REGISTER-BASED HARDWARE
The leaf node decoder characterized by (6), (7), (11) and
(12) can be further simplified to facilitate hardware imple-
mentation. While (11) and (12) support the soft decoding of
any pre-transformed polar codes [6] (e.g., CA-Polar [3], and
PAC-Polar [5]), they do not exploit the regular structure of
PC-Polar [4] for further simplification.
We propose a cyclic-shift-register (CSR) based soft feed-
back generator. Compared with the general method of (11) and
(12), it does not need to store the factor graph in Fig. 4 and all
the variables. This is a huge complexity reduction given the
irregularity of the graph and the number of variables therein.
The LLR calculation can also be simplified. For information
bits, we found that the soft feedback can be set to zero.
For PC bits, the damping factor λP can be set to one
to avoid multiplication operations. As will be shown, both
simplifications incur only negligible performance loss.
The simplified soft feedback generation is

βu =∞, for u ∈ F
βu = f(αu′0 , αu′1 , ..., αu′N ) |{u′0...u′N}=I(u), for u ∈ P
βu = 0, for u ∈ I
(13)
The simplified circuit is shown in Fig. 6, and described as
follows. We set up an array of registers “∆” of length L. Each
register processes one parity-check chain. The registers only
store the intermediate states that are necessary for generating
the next soft feedback.
Before each iteration, all register states are reset to zero. As
the registers shift, the f -function in (13) can be calculated on
the fly. Upon decoding an information bit u ∈ I, the input
soft LLR αu is accumulated into the register ∆ as follows
∆x = f(∆x, αu), for u ∈ I, x = l(u)%L. (14)
Upon decoding a PC bit u, the soft feedback βu can be
immediately obtained as
βu = ∆x, for u ∈ P , x = l(u)%L. (15)
?? ?? ?? ?????
?
???????????
????????????????????????????
??????????????????????????
?
?
????????????????????????????
?
?
????????????????????????????????????
???????????????????????????????????
??????????????????????????????
?
?
?
?????
??????????
Fig. 6. Soft feedback generator for PC-SCAN leaf decoder
EsN0(dB)
6.4 6.6 6.8 7 7.2 7.4
10-4
10-3
10-2
N=128,K=96
Iter=2 PC 
Iter=4 PC 
Iter=2 CSR 
Iter=4 CSR 
EsN0(dB)
0.5 1 1.5 2
FE
R
10-3
10-2
N=128,K=32
Iter=2 PC 
Iter=4 PC 
Iter=2 CSR 
Iter=4 CSR 
EsN0(dB)
3.8 4 4.2 4.4 4.6 4.8
10-4
10-3
10-2
N=128,K=64
Iter=2 PC 
Iter=4 PC 
Iter=2 CSR 
Iter=4 CSR 
Fig. 7. FC-PC-Polar, N=128, K=[32,64,96], A=1.0, performances of PC-SCAN using the damping factor λ
I˜,best
=[0.67,0.67,0.5] and CSR-SCAN.
EsN0(dB)
5.8 6 6.2 6.4 6.6
10 -4
10 -3
10 -2
N=512,K=384
Iter=2 PC
Iter=4 PC
Iter=2 CSR
Iter=4 CSR
EsN0(dB)
-0.2 0 0.2 0.4 0.6
FE
R
10 -3
10 -2
N=512,K=128
Iter=2 PC
Iter=4 PC
Iter=2 CSR
Iter=4 CSR
EsN0(dB)
3 3.2 3.4 3.6 3.8 4
10 -4
10 -3
10 -2
N=512,K=256
Iter=2 PC
Iter=4 PC
Iter=2 CSR
Iter=4 CSR
Fig. 8. MC-PC-Polar, N=512, K=[128,256,384], A=1.5, performances of PC-SCAN using the damping factor λ
I˜,best
=[0.67,0.67,0.5] and CSR-SCAN.
EsN0(dB)
-3.2 -3.1 -3 -2.9 -2.8
×10 -3
0.6
0.8
1
1.2
1.4
1.6
N=256,K=25
Iter=2 PC
Iter=4 PC
Iter=2 CSR
Iter=4 CSR
EsN0(dB)
-1.5 -1 -0.5 0
FE
R
10 -4
10 -3
10 -2
N=128,K=21
Iter=2 PC
Iter=4 PC
Iter=2 CSR
Iter=4 CSR
EsN0(dB)
-0.5 0 0.5
10 -3
10 -2
N=128,K=25
Iter=2 PC
Iter=4 PC
Iter=2 CSR
Iter=4 CSR
Fig. 9. NR-PC-Polar, N=128, K=[21,25] and N=256, K=25, performances between PC-SCAN using the damping factor λ
I˜,best
=[0.67,0.5,0.5] and CSR-SCAN.
Therefore, to implement PC-SCAN, we only need a small
additional circuit on top of SCAN, thanks to the structural reg-
ularity of PC-Polar [4]. We name this optimized method CSR-
SCAN decoder. The circuit comprises only an f -function,
defined in (10), and a cyclic buffer of length L. As shown
in Fig. 6, it is very similar to the PC pre-coding circuit in
Fig. 2. Both are very hardware friendly and highly efficient in
terms of area, power and latency.
VI. PERFORMANCES
We simulate the performances of PC-SCAN decoder using
the best damping factor λI˜
5 and CSR-SCAN decoder within
all the PC-types introduced in section III. The results in Fig. 7,
Fig. 8 and Fig. 9 show such simplifications incur minimum
performance loss. After the first iteration, the optimized circuit
produces the same performance as the original one. With more
iterations, a little performance loss can be observed. For all
simulated cases, the FER loss is within 0.05dB.
5The damping factor is obtained empirically through simulations.
EsN0(dB)
-1 0 1 2
FE
R
10-5
10-4
10-3
10-2
10-1
N=128,K=32
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
2.5 3 3.5 4 4.5 5 5.5
10-6
10-5
10-4
10-3
10-2
10-1
N=128,K=64
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
5.5 6 6.5 7 7.5
10-6
10-5
10-4
10-3
10-2
10-1
N=128,K=96
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
Fig. 10. FC-PC-Polar, N=128, K=[32,64,96], A=1.0, performances of SC decoder and CSR-SCAN decoder.
EsN0(dB)
-1 0 1 2
FE
R
10-6
10-5
10-4
10-3
10-2
10-1
N=128,K=32
SC FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
2 3 4 5
10-6
10-5
10-4
10-3
10-2
10-1
N=128,K=64
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
5.5 6 6.5 7 7.5
10-6
10-5
10-4
10-3
10-2
10-1
N=128,K=96
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
Fig. 11. MC-PC-Polar, N=128, K=[32,64,96], A=1.0, performances of SC decoder and CSR-SCAN decoder.
EsN0(dB)
5.5 6 6.5
10-5
10-4
10-3
10-2
10-1
N=512,K=384
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=2 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
-1 -0.5 0 0.5 1
FE
R
10-5
10-4
10-3
10-2
10-1
N=512,K=128
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
2.5 3 3.5 4
10-5
10-4
10-3
10-2
10-1
N=512,K=256
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
Fig. 12. FC-PC-Polar, N=512, K=[128,256,384], A=1.5, performances of SC decoder and CSR-SCAN decoder.
We also compare the performance between SC decoder and
CSR-SCAN decoder. We show the FER and BER performance
comparison in the Fig. 10 ∼ Fig. 14. We find that in the cases
of shorter code length (N=128), the FER of CSR-SCAN after
the first iteration is 0.1dB inferior to that of SC decoder at
FER = 10−3, while the BER is 0.1dB better. After the second
iteration, both FER and BER of CSR-SCAN are better than
those of SC decoder. In the cases of long codes (N=512),
CSR-SCAN’s slope at the waterfall region is better than that
of SC decoder, and the performances after the second iteration
are similar to that of SC decoder when FER = 10−3. The
NR-PC-Polar has 3 PC-bits, and exhibits less gain from the
2-rd to the 4-th iteration. The FER of CSR-SCAN’s second
iteration is better than that of SC-decoder by 0.1dB.
VII. CONCLUSION
In this paper, we propose a soft-output PC-SCAN de-
coder for pre-transformed polar codes including CA-Polar,
PC-Polar and PAC-Polar. The proposed algorithm treats PC
bits as “soft constraints” to process the soft information
generated by SCAN. An additional factor graph is formulated
to process these constraints. According to the factor graph,
EsN0(dB)
5.5 6 6.5 7
10-6
10-5
10-4
10-3
10-2
10-1
N=512,K=384
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
-1 -0.5 0 0.5 1
FE
R
10-5
10-4
10-3
10-2
10-1
N=512,K=128
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
2.5 3 3.5 4
10-6
10-5
10-4
10-3
10-2
10-1
N=512,K=256
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=4 BER
SCAN Iter=2 BER
SCAN Iter=1 BER
Fig. 13. MC-PC-Polar, N=512, K=[128,256,384], A=1.5, performances of SC decoder and CSR-SCAN decoder.
EsN0(dB)
-5 -4 -3 -2
10-4
10-3
10-2
10-1
N=512,K=384
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
-3 -2 -1 0
FE
R
10-5
10-4
10-3
10-2
10-1
N=128,K=21
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 FER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
EsN0(dB)
-2 -1 0 1
10-5
10-4
10-3
10-2
10-1
N=512,K=256
SC FER
SCAN Iter=1 FER
SCAN Iter=2 FER
SCAN Iter=4 BER
SC BER
SCAN Iter=1 BER
SCAN Iter=2 BER
SCAN Iter=4 BER
Fig. 14. NR-PC-Polar, N=128, K=[21,25] and N=256, K=25, performances of SC decoder and CSR-SCAN decoder.
four types of leaf nodes are defined, i.e., frozen/PC/checked
information/unchecked information, and decoded accordingly.
With focus on the hardware implementation, a cyclic-shift-
register-based optimization is proposed to dramatically reduce
the hardware overhead named CSR-SCAN decoder. Finally,
performance simulations show both the gain from PC bits and
the insignificant performance loss due to CSR-SCAN decoder.
REFERENCES
[1] E. Arikan, “Channel polarization: A method for constructing capacity-
achieving codes for symmetric binary-input memoryless channels,” IEEE
Transactions on Information Theory, vol. 55, no. 7, pp. 3051–3073, July
2009.
[2] I. Tal and A. Vardy, “List decoding of polar codes”, IEEE International
Symposium on Information Theory Proceedings pp. 1–5, 2011.
[3] K. Niu, K. Chen, “CRC-aided decoding of polar codes” IEEE Commu-
nications Letters, vol. 16, no. 10, pp. 1668–1671, Oct. 2012.
[4] H. Zhang, R. Li, J.Wang, S. Dai, G. Zhang, Y. Chen, H. Luo, and J.Wang,
“Parity-check polar coding for 5G and beyond,” IEEE International
Conference on Communications (ICC), pp. 1–6, May 2018.
[5] E. Arikan, “From sequential decoding to channel polarization and back
again,” arXiv preprint arXiv:1908.09594 (2019).
[6] B. Li, H. Zhang, J. Gu, “On Pre-transformed Polar Codes,” arXiv preprint
arXiv:1912.06359 (2019).
[7] R1-1608862,“Polar Code Construction for NR”, 3GPP TSG RAN WG1
No.86bis Meeting, Lisbon, Portugal, Oct. 10th–14th, 2016.
[8] R1-1611254,“Details of the polar code design”, 3GPP TSG RAN WG1
No.87 Meeting, Reno, USA, Nov. 10th–14th, 2016.
[9] 3GPP,“NR; Multiplexing and channel coding”, 3GPP TS 38.212,15.5.0,
Mar. 2019.
[10] C. Berrou, A. Glavieux and P. Thitimajshima, “Near Shannon limit
error-correcting coding and decoding: Turbo-codes,” IEEE International
Conference on Communications(ICC), May 1993.
[11] J. Hagenauer, “The Turbo principle: Tutorial introduction and state of
the art,” International Symposium on Turbo Codes (ISTC), Brest, France,
pp. 1–11, Sep. 1997.
[12] U. Fayyaz and J. Barry, “Polar Codes for Partial Response Channels,”
IEEE International Conference on Communications (ICC), pp. 4337–
4341, Jun. 2013.
[13] A. Alamdar-Yazdi and F. R. Kschischang, “A Simplified Successive-
Cancellation Decoder for Polar Codes,” IEEE Communications Letters,
vol. 15, no. 12, pp. 1378–1380, Dec. 2011.
[14] E. Arikan,“Systematic polar coding,” IEEE communications letters, vol.
15, no. 8, pp. 860–862, Aug. 2011.
[15] R1-167209 “Polar code design and rate-matching”, 3GPP TSG RAN
WG1 No. 86 Meeting, Gothenburg, Sweden, Aug. 22nd–26th, 2016.
