A Brief Overview of CRC Implementation for 5G NR by Wu, Hao
Selection of our books indexed in the Book Citation Index 
in Web of Science™ Core Collection (BKCI)
Interested in publishing with us? 
Contact book.department@intechopen.com
Numbers displayed above are based on latest data collected. 
For more information visit www.intechopen.com
Open access books available
Countries delivered to Contributors from top 500 universities
International  authors and editors
Our authors are among the
most cited scientists
Downloads
We are IntechOpen,
the world’s leading publisher of
Open Access books
Built by scientists, for scientists
12.2%
122,000 135M
TOP 1%154
4,800
Chapter
A Brief Overview of CRC
Implementation for 5G NR
Hao Wu
Abstract
In fifth generation (5G) new radio (NR), the medium access control (MAC)
layer organizes the data into the transport block and transmits it to the physical
layer. The transport block consists of up to million bits. When the transport block
size exceeds a threshold, the transport block is divided into multiple equal size code
blocks. The code block consists of up to 8448 bits. Both the transport block and
the code block have a cyclic redundancy check (CRC) attached. Due to the
difference in the size of the transport block and the code block, the CRC processing
scheme suitable for the transport block and that suitable for the code block are
different. This chapter gives an overview of the CRC implementation in 5G NR.
Keywords: 5G, NR, CRC, transport block, code block
1. Introduction
In order to provide high data transmission rates, the bandwidth of mobile
communication systems is increasing. In fourth generation (4G) long term evolu-
tion (LTE), the maximum transmission bandwidth for one component carrier is
20 MHz [1]. In fifth generation (5G) new radio (NR), the frequency bands are
divided into two parts: frequency range 1 (FR1) below 6 GHz and frequency range 2
(FR2) above 24.25 GHz. The maximum transmission bandwidth for one component
carrier is 100 MHz and 400 MHz in FR1 and FR2 respectively [2]. The increasing
system bandwidth brings new problems to the design of the transmitter and the
receiver. In this chapter of the book, we focus on the cyclic redundancy check
(CRC) implementation in 5G NR.
In 5G NR, there are many physical channels defined in the downlink and the
uplink [3]. The downlink physical channels consist of the physical downlink shared
channel (PDSCH), the physical downlink control channel (PDCCH), the physical
broadcast channel (PBCH), etc. The uplink physical channels consist of physical
uplink shared channel (PUSCH), the physical uplink control channel (PUCCH), the
physical random access channel (PRACH), etc. The PDSCH and the PDSCH are
mainly used to transmit data. The usage scenarios of 5G NR consist of enhanced
mobile broadband (eMBB), massive machine-type communications (mMTC) and
ultra-reliable and low latency communications (URLLC) [4, 5]. The usage scenario
of the eMBB requires high data transmission rates. As a consequence, we focus on
the PDSCH and the PUSCH in this chapter.
The medium access control (MAC) layer organizes the data into the transport
block and transmits it to the physical layer. In 5G NR, the maximum transport block
1
size is 1,277,992 [6]. The processing of the transport block is shown in Figure 1 [7].
If the transport block size is larger than 3824, a 16-bit CRC is added at the end of the
transport block. Otherwise, a 24-bit CRC is added at the end of the transport block.
The transport block is divided into multiple equal size code blocks when the trans-
port block size exceeds a threshold. For quasi-cyclic low-density parity-check code
(QC-LDPC) base graph 1, the threshold is equal to 8448. For QC-LDPC base graph
2, the threshold is equal to 3840. In 5G NR, the maximum code block size number
is 8448. An additional 24-bit CRC is added at the end of each code block when there
is a segmentation. Due to the difference in the size of the transport block and the
code block, the CRC processing scheme suitable for the transport block and that
suitable for the code block are different.
The rest of this chapter is organized as follows. Section 2 describes the system
model of the transport block and the code block in 5G NR. Section 3 gives two
properties of the CRC. Section 4 presents the overview of the CRC implementation.
Finally, Section 5 gives the conclusion.
2. System model
Let a ¼ a0, a1,… , aL1, aL, aLþ1, … , aLþN1½  be the transport block including
the transport block level CRC, where L is the transport block size and N is the
transport block level CRC size. Note that p ¼ aL, aLþ1,… , aLþN1½  is the transport
block level CRC. If L is smaller than or equal to 3824, then N is equal to 16 and p
is generated by the following cyclic generator polynomial:
g16 xð Þ ¼ x
16 þ x12 þ x5 þ 1 (1)
If L is larger than 3824, then N is equal to 24 and p is generated by the following
cyclic generator polynomial:
g24A xð Þ ¼ x
24 þ x23 þ x18 þ x17 þ x14 þ x11 þ x10 þ x7 þ x6 þ x5 þ x4 þ x3 þ xþ 1
(2)
When LþN is larger thanM, the transport block including the transport block
level CRC is segmented into multiple code blocks. Let R be code rate of the initial
transmission indicated by the modulation and coding scheme (MCS) index. If
L> 292 and R>0:67 or L> 3824 and R>0:25, then QC-LDPC base graph 1 is used
andM is equal to 8448. Otherwise, QC-LDPC base graph 2 is used andM is equal
to 3840.
When there is no segmentation, the number of code blocks C is equal to 1. When
there is a segmentation, the number of code blocks C is equal to
C ¼ LþNð Þ= M 24ð Þd e (3)
Figure 1.
The transport block and the code block.
2
Moving Broadband Mobile Communications Forward - Intelligent Technologies for 5G…
In the following sections, we mainly consider the case that there is a segmenta-
tion. Let ci ¼ ci0, c
i
1,… , c
i
K1
 
be the ith code block, where K is the code block size
and is equal to
K ¼ LþNð Þ=Cþ 24 (4)
Note that the procedure of the transport block size determination guarantees
that LþNð Þ is divisible by C. ciK24, c
i
K23, … , c
i
K1
 
is the code block level CRC,
which is generated by the cyclic generator polynomial
g24B xð Þ ¼ x
24 þ x23 þ x6 þ x5 þ xþ 1 (5)
cij is equal to
cij ¼ ai K24ð Þþj (6)
where 0≤ j≤K  25. In the following, the processing of the transport block
includes: QC-LPDC encoding, rate matching, bit interleaving and code block con-
catenation. The encoded transport block is transmitted over the air after the symbol
level processing.
At the receiver side, the following steps are carried out for the transport block:
code block segmentation, bit de-interleaving, de-rate matching, QC-LPDC
decoding, code block concatenation. We need to check whether each code block and
the transport block are correctly received. Let di ¼ di0, d
i
1,… , d
i
K1
 
be the ith
received code block after the hard decision and e ¼ e0, e1,… , eLþN1½  be the
received transport block after the hard decision. e j is equal to
e j ¼ d
v
u (7)
where v ¼ ⌊ j= K  24ð Þ⌋, u ¼ mod j,K  24ð Þ and 0≤ j≤LþN  1. The
undetected error probability is required to be less than 106 in 5G NR [8, 9]. Since
the parity check capacity of QC-LDPC codes alone cannot meet the undetected
error probability requirement of 5G NR [8, 9], we need to use the CRC check to
determine whether di and e are correctly received.
3. Properties of the CRC
In this section, we give two properties of the CRC. These properties are useful in
the CRC implementation. Before giving these properties, we define some variables.
Let A xð Þ and B xð Þ be the polynomials. Let g xð Þ be the cyclic generator polynomial.
CRCg xð Þ A xð Þ½  is defined as the remainder when A xð Þ is divided by g xð Þ. The two
properties are listed as follows.
Property 1.
CRCg xð Þ A xð ÞB xð Þ½  ¼ CRCg xð Þ CRCg xð Þ A xð Þ½ CRCg xð Þ B xð Þ½ 
 
(8)
Property 1 implies that CRCg xð Þ A xð ÞB xð Þ½  can be obtained by computing the
CRC of A xð Þ and B xð Þ independently.
Property 2.
3
A Brief Overview of CRC Implementation for 5G NR
DOI: http://dx.doi.org/10.5772/intechopen.91790
CRCg xð Þ A xð Þ þ B xð Þ½  ¼ CRCg xð Þ A xð Þ½  þ CRCg xð Þ B xð Þ½ : (9)
Property 2 implies that CRCg xð Þ A xð Þ þ B xð Þ½  can be obtained by computing the
CRC of A xð Þ and B xð Þ independently.
The proof of the property 1 and the property 2 can be found in Refs. [10, 11]. It
is omitted for brevity. g xð Þ in the expression of CRCg xð Þ A xð Þ½  is clear from the
context. As a consequence, g xð Þ in the expression of CRCg xð Þ A xð Þ½  is omitted in
the following.
4. Overview of the CRC implementation
In this section, we give an overview of the CRC implementation. In the
following, the received transport block after the hard decision e is used as an
example. The implementation is easily generalized to other cases.
4.1 CRC implementation by direct calculation
In this scheme, the CRC of e is directly calculated by the division of polynomial
using modulo-2 arithmetic.
Figure 2 illustrates an example. The dividend is equal to x5 þ x4 þ xþ 1 and
the divisor is equal to x2 þ xþ 1. The division of polynomial begins by putting
x5 þ x4 þ x3 below x5 þ x4. Subtracting and bringing down the next term give us
the intermediate variable x3 þ x. This process is repeated until the degree of the
intermediate variable is less than 2. Finally, we obtain that the quotient is equal
to x3 þ xþ 1 and the remainder is equal to x. That is,
CRC x5 þ x4 þ xþ 1
 
¼ x (10)
The division of polynomial using modulo-2 arithmetic is a computationally
intensive operation. In the worst case, it requires a shift operation and an XOR logic
operation for each bit of e. As a consequence, this scheme is rarely used in actual
systems. In order to solve the problem of the direct calculation, many schemes have
been proposed in the literatures.
For example, the CRC implementation for g xð Þ ¼ x5 þ x3 þ xþ 1 is shown in
Figure 3 [12, 13]. The parallelism of this CRC implementation is 1 and thus one bit is
processed on every clock cycle. Multiple bits can be processed on every clock cycle
Figure 2.
The division of polynomial using modulo-2 arithmetic.
4
Moving Broadband Mobile Communications Forward - Intelligent Technologies for 5G…
to speed the CRC calculation. For example, another CRC implementation for
g xð Þ ¼ x5 þ x3 þ xþ 1 is shown in Figure 4 [14, 15]. The parallelism of this CRC
implementation is 3 and thus three bits are processed on every clock cycle. From
Figures 3 and 4, it is clear that parallelism comes at the expense of the increased
circuit complexity.
4.2 CRC implementation by parallel processing
In this scheme, e is segmented into multiple blocks and the CRC of each block is
obtained by parallel processing. e is segmented into multiple blocks [16]:
e0, e1, … , eM1 (11)
The size of eM1 is n and the size of e j is m, where 0≤ j≤M 2. Note that LþN
is equal to nþm M 1ð Þ. As a consequence, e can be expressed as
e ¼ e0x M2ð Þmþn þ e1x M3ð Þmþn þ … þ eM3xnþm þ eM2xn þ eM1
The CRC of e is given by
CRC e½  ¼ CRC e0x M2ð Þmþn þ … þ eM2xn þ eM1
h i
¼ CRC CRC e0
 
CRC x M2ð Þmþn
h i
þ … þ CRC eM2
 
CRC xn½ 
h i
þ CRC eM1
 
¼ CRC CRC e0
 
CRC x M2ð Þm
h i
þ … þ CRC eM2
 h i
CRC xn½ 
h i
þ CRC eM1
 
(12)
The above expression explains how CRC e½  is obtained. The detail is shown in
Figure 5. CRC xm½ , CRC x2m½ , … , CRC x M2ð Þm
 
and CRC xn½  do not depend on the
transport block size and can be precomputed. Since n is in the range 0,m 1½ ,
variables that need to be precomputed include
Figure 3.
CRC implementation for g xð Þ ¼ x5 þ x3 þ xþ 1.
Figure 4.
CRC implementation for g xð Þ ¼ x5 þ x3 þ xþ 1.
5
A Brief Overview of CRC Implementation for 5G NR
DOI: http://dx.doi.org/10.5772/intechopen.91790
CRC x1
 
, CRC x2
 
, … , CRC xm1
 
, CRC xm½ , CRC x2m
 
, … , CRC x M2ð Þm
h i
(13)
As a consequence, the number of variables that needs to be precomputed is
mþM 3.
It is clear that the memory that needs to store the variables increases with the
transport block size. To reduce the memory, CRC xαm½  can be recursively calculated
by using CRC xm½  [17]. That is, CRC xαm½  is recursively obtained by the following
expression
CRC xαm½  ¼ CRC CRC x α1ð Þm
h i
CRC xm½ 
h i
(14)
In this way, the variables that need to be precomputed include
CRC x1
 
, CRC x2
 
, … , CRC xm1
 
, CRC xm½  (15)
As a consequence, the number of variables that needs to be precomputed is m.
4.3 CRC implementation by serial processing
In this scheme, e is segmented into multiple blocks and the CRC of each block is
obtained by serial processing. e is segmented into multiple blocks [18]:
e0, e1, … , eM1 (16)
The size of eM1 is n and the size of e j is m, where 0≤ j≤M 2. Note that LþN
is equal to nþm M 1ð Þ. e can be expressed as
e ¼ e0x M2ð Þmþn þ e1x M3ð Þmþn þ … þ eM3xnþm þ eM2xn þ eM1 (17)
The CRC of e is given by
Figure 5.
CRC implementation by parallel processing.
6
Moving Broadband Mobile Communications Forward - Intelligent Technologies for 5G…
T1 ¼ CRC e
0x p1ð Þm þ … þ e1p1
h i
T2 ¼ CRC e
px p1ð Þm þ … þ e2p1
h i
þ CRC T1x
mp½ 
…
Te ¼ CRC e
e1ð Þpx p1ð Þm þ … þ eep1
h i
þ CRC Te1x
mp½ 
Teþ1 ¼ CRC e
epx Mep2ð Þm þ … þ eM2
h i
þ CRC Tex
MeP1ð Þm
h i
Teþ2 ¼ CRC Teþ1x
n½  þ CRC eM1
 
(18)
where e ¼ ⌊ M 1ð Þ=P⌋. The above expression explains how CRC e½  is calculated.
The detail is shown in Figure 6. CRC xm½ , CRC x2m½ , … , CRC x p1ð Þm
 
and CRC xn½ 
do not depend on the transport block size and can be precomputed. Since n is in
the range 0,m 1½ , variables that need to be precomputed include
CRC x1
 
, CRC x2
 
, … , CRC xm1
 
, CRC xm½ , CRC x2m
 
, … , CRC x p1ð Þm
h i
(19)
As a consequence, the number of variables that needs to be precomputed is
mþ p 2.
It is clear that thememory that needs to store the variables increaseswith the trans-
port block size. To reduce thememory, CRC xαm½ can be recursively calculated by using
CRC xm½  [17]. That is, CRC xαm½  is recursively obtained by the following expression
CRC xαm½  ¼ CRC CRC x α1ð Þm
h i
CRC xm½ 
h i
(20)
In this way, the variables that need to be precomputed include
Figure 6.
CRC implementation by serial processing.
7
A Brief Overview of CRC Implementation for 5G NR
DOI: http://dx.doi.org/10.5772/intechopen.91790
CRC x1
 
, CRC x2
 
, … , CRC xm1
 
, CRC xm½  (21)
As a consequence, the number of variables that needs to be precomputed is m.
4.4 The Sarwate algorithm
Sarwate proposes an algorithm based on the lookup table [19]. The detail and the
proof of the algorithm can be found in [19]. The Sarwate algorithm is shown in
Figure 7 [20]. The Sarwate algorithm uses a single table of 256 32-bit elements and
reads the bits byte by byte. Modern processors usually access 32 bits or 64 bits at a
Figure 7.
The Sarwate algorithm.
Figure 8.
The slicing-by-4 algorithm.
Figure 9.
The slicing-by-8 algorithm.
8
Moving Broadband Mobile Communications Forward - Intelligent Technologies for 5G…
time. As a consequence, the Sarwate algorithm is not efficient. Some schemes have
been proposed in the literatures to solve this problem.
4.5 The slicing-by-4 and slicing-by-8 algorithms
Kounavis and Berry propose the slicing-by-4 and slicing-by-8 algorithms based
on the lookup table [20]. The detail and the proof of the algorithms can be found in
[20]. The slicing-by-4 and slicing-by-8 algorithms are shown in Figures 8 and 9
respectively [20]. The slicing-by-4 algorithm uses four tables of 256 32-bit elements
and reads 32 bits at a time. The slicing-by-8 algorithm uses eight tables of 256 32-bit
elements and reads 64 bits at a time. The performance of the slicing-by-4 and
slicing-by-8 algorithms is improved compared to the Sarwate algorithm.
5. Conclusion
In 5G NR, the transport block consists of up to million bits and the code block
consists of up to 8448 bits. Due to the difference in the size of the transport block
and the code block, the scheme of the CRC processing suitable for the transport
block and that suitable for the code block are different. This chapter gives an
overview of the CRC implementation in 5G NR.
Conflict of interest
The authors declare no conflict of interest.
Author details
Hao Wu1,2
1 Department of Wireless Product Research and Design Institute, ZTE Corporation,
Shenzhen, China
2 State Key Laboratory of Mobile Network and Mobile Multimedia Technology,
ZTE Corporation, Shenzhen, China
*Address all correspondence to: wu.hao19@zte.com.cn
©2020TheAuthor(s). Licensee IntechOpen. This chapter is distributed under the terms
of theCreativeCommonsAttribution License (http://creativecommons.org/licenses/
by/3.0),which permits unrestricted use, distribution, and reproduction in anymedium,
provided the original work is properly cited.
9
A Brief Overview of CRC Implementation for 5G NR
DOI: http://dx.doi.org/10.5772/intechopen.91790
References
[1] Erik D, Stefan P, Johan S. 4G:
LTE/LTE-advanced for Mobile
Broadband. 2nd ed. Oxford, UK:
Elsevier; 2014
[2] Erik D, Stefan P, Johan S. 5G NR: The
Next Generation Wireless Access
Technology. London, UK: Elsevier; 2018
[3] 3GPP TS 38.211, V15.3.0, NR;
Physical channels and modulation
(Release 15). 2018-09
[4]Hyoungju J, Sunho P, Jeongho Y,
Younsun K, Juho L, Byonghyo S. Ultra-
reliable and low-latency
communications in 5G downlink:
Physical layer aspects. IEEE Wireless
Communications. 2018;25:124-130. DOI:
10.1109/MWC.2018.1700294
[5] Petar P, Kasper Floe T, Osvaldo S,
Giuseppe D. 5G wireless network slicing
for eMBB, URLLC, and mMTC: A
communication-theoretic view. IEEE
Access. 2018;6:55765-55779. DOI:
10.1109/ACCESS.2018.2872781
[6] 3GPP TS 38.214, V15.3.0, NR;
physical layer procedures for data
(Release 15). 2018-09
[7] 3GPP TS 38.212, V15.3.0, NR;
multiplexing and channel coding
(Release 15). 2018-09
[8] R1-1713458. Qualcomm
Incorporated, CRC attachment. 3GPP
TSG RAN Meeting #90; August 21–25,
2017; Prague, Czechia
[9]Hao W. Hard decision of the zero a
posteriori LLR in 5G NR. Internet
Technology Letters. 2020;3:e146. DOI:
10.1002/itl2.146
[10] Yan S, Min SK. A table-based
algorithm for pipelined CRC calculation.
In: Proceedings of the IEEE
International Conference on
Communications (ICC’10); 23-27 May
2010; Cape Town, South Africa: IEEE;
2010. pp. 1-5
[11]Hao W, Fang W, Yuqing Y. A
distributed CRC early termination
scheme for high throughput QC-LDPC
codes. In: Proceedings of International
Conference on Wireless
Communications and Signal Processing
(WCSP) (WCSP ’18); 18-20 October
2018; Hangzhou, China: IEEE; 2018.
pp. 1-5
[12] TongBi P, Charles Z. High-speed
parallel CRC circuits in VLSI. IEEE
Transactions on Communications. 1992;
40:653-657. DOI: 10.1109/26.141415
[13] Richard EB. Algebraic Codes for
Data Transmission. Cambridge, UK:
Cambridge University Press; 2003
[14] Chao C, Keshab KP. High-speed
parallel CRC implementation based on
unfolding, pipelining, and retiming.
IEEE Transactions on Circuits and
Systems II: Express Briefs. 2006;53:
1017-1021. DOI: 10.1109/TCSII.2006.
882213
[15] Keshab KP. VLSI Digital Signal
Processing Systems: Design and
Implementation. New York, USA:
John Wiley & Sons; 1999
[16] Ji HM, Killian E. Fast parallel CRC
algorithm and implementation on a
configurable processor. In: Proceedings
of the IEEE International Conference on
Communications (ICC’02); 28 April-2
May 2002. New York, USA: IEEE; 2002.
pp. 1813-1817
[17]Hyeji K, Injun C, Wooseok B,
Jong-yeol L, Ji-Hoon K. Distributed CRC
architecture for high-radix parallel
turbo decoding in LTE-advanced
systems. IEEE Transactions on Circuits
and Systems II: Express Briefs. 2015;62:
10
Moving Broadband Mobile Communications Forward - Intelligent Technologies for 5G…
906-910. DOI: 10.1109/TCSII.2015.
2435131
[18]Hao W, Tao L, Jin X, Fang W.
Parallel CRC architecture for broadband
communication systems. Electronics
Letters. 2017;53:1439-1441. DOI:
10.1049/el.2017.1029
[19] Sarwate DV. Computation of cyclic
redundancy checks via table look-up.
Communications of the ACM. 1988;31:
1008-1014. DOI: 10.1145/63030.63037
[20]Michael EK, Frank LB. Novel table
lookup-based algorithms for high-
performance CRC generation. IEEE
Transactions on Computers. 2008;57:
1550-1560. DOI: 10.1109/TC.2008.85
11
A Brief Overview of CRC Implementation for 5G NR
DOI: http://dx.doi.org/10.5772/intechopen.91790
