LDPC code block segmentation
11025275 · 2021-06-01
Assignee
Inventors
- Sara Sandberg (Luleå, SE)
- Mattias Andersson (SUNDBYBERG, SE)
- Yufei Blankenship (Kildeer, IL)
- Amirpasha Shirazinia (SOLNA, SE)
Cpc classification
H03M13/6516
ELECTRICITY
H03M13/6522
ELECTRICITY
H03M13/1102
ELECTRICITY
H03M13/114
ELECTRICITY
H03M13/116
ELECTRICITY
H03M13/09
ELECTRICITY
H03M13/6393
ELECTRICITY
H03M13/6306
ELECTRICITY
International classification
H03M13/09
ELECTRICITY
Abstract
According to some embodiments, a method in a wireless transmitter comprises: receiving a plurality of bits for a wireless transmission; determining a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code; segmenting the plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size; and transmitting the one or more code block segments to a wireless receiver. In particular embodiments, the design parameters of the channel code limit the maximum code block size to Kmax for any code rate. The determined maximum code block size may be limited by code rate and Nmax such that the maximum code block size does not exceed code rate times Nmax.
Claims
1. A method in a wireless transmitter, the method comprising: receiving, at the wireless transmitter, a plurality of bits for a wireless transmission; determining, at the wireless transmitter, a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code; segmenting, at the wireless transmitter, the plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size; and transmitting, at the wireless transmitter, the one or more code block segments to a wireless receiver.
2. The method of claim 1, wherein the design parameters of the channel code limit the maximum code block size to Kmax for any code rate.
3. The method of claim 1, wherein the determined maximum code block size is limited by code rate and Nmax such that the maximum code block size does not exceed code rate times Nmax.
4. The method of claim 3, wherein the code rate is the maximum of the minimum code rate for which the channel code is designed and the target code rate.
5. The method of claim 3, wherein Nmax is adjusted by subtraction of the number of punctured systematic bits.
6. The method of claim 3, wherein the determined maximum code block size is further adjusted by subtracting the length of the CRC attached to each code block.
7. The method of claim 1, wherein segmenting the plurality of bits further comprises allowing code block segments with a maximum code block size larger than the determined maximum code block size as long as the code block segment size does not exceed Kmax.
8. The method of claim 1, wherein the wireless transmitter comprises a network node.
9. The method of claim 1, wherein the wireless transmitter comprises a wireless device.
10. A wireless transmitter comprising processing circuitry, the processing circuitry operable to: receive a plurality of bits for a wireless transmission; determine a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code; segment the plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size; and transmit the one or more code block segments to a wireless receiver.
11. The wireless transmitter of claim 10, wherein the design parameters of the channel code limit the maximum code block size to Kmax for any code rate.
12. The wireless transmitter of claim 10, wherein the determined maximum code block size is limited by code rate and Nmax such that the maximum code block size does not exceed code rate times Nmax.
13. The wireless transmitter of claim 12, wherein the code rate is the maximum of the minimum code rate for which the channel code is designed and the target code rate.
14. The wireless transmitter of claim 12, wherein Nmax is adjusted by subtraction of the number of punctured systematic bits.
15. The wireless transmitter of claim 12, wherein the determined maximum code block size is further adjusted by subtracting the length of the CRC attached to each code block.
16. The wireless transmitter of claim 10, wherein the processing circuitry is operable to segment the plurality of bits by allowing code block segments with a maximum code block size larger than the determined maximum code block size as long as the code block segment size does not exceed Kmax.
17. The wireless transmitter of claim 10, wherein the wireless transmitter comprises a network node.
18. The wireless transmitter of claim 10, wherein the wireless transmitter comprises a wireless device.
19. A wireless transmitter comprising a receiving module, a determining module, a segmenting module, and a transmitting module; the receiving module operable to receive a plurality of bits for a wireless transmission; the determining module operable to determine a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code; the segmenting module operable to segment the plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size; and the transmitting module operable to transmit the one or more code block segments to a wireless receiver.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1) For a more complete understanding of the embodiments and their features and advantages, reference is now made to the following description, taken in conjunction with the accompanying drawings, in which:
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
DETAILED DESCRIPTION
(11) Fifth generation (5G) networks, such as Third Generation Partnership Project (3GPP) New Radio (NR), that support requirements such as enhanced mobile broadband (eMBB), may use channel coding schemes such as low-density parity check (LDPC). One problem with using LDCP with existing solutions is that if the code block segmentation procedure is based on the maximum information block length K.sub.max that the channel code is designed for, like in long term evolution (LTE), hardware must be provisioned for a maximum codeword block length corresponding to the maximum information block size combined with the lowest code rate, which gives the largest possible codeword block size. However, this combination is rarely used in practice. Thus, the hardware area efficiency for other, more often used, combinations of information block length and code rate is low when hardware is provisioned for this case.
(12) Particular embodiments obviate the problems described above and include code block segmentation based on the structure and design parameters of the LDPC codes proposed for NR. In particular embodiments, given a fixed maximum codeword length, which the LDPC decoder hardware is provisioned to support, the code block segmentation method divides the information bits of the transport block into code blocks based on desired code rate and the minimum code rate that the LDPC code has been extended to.
(13) For example, by applying the code block segmentation scheme of particular embodiments, the maximum codeword length Nmax that the hardware is provisioned for is used more often. The area efficiency of the decoder is thereby higher. Another advantage is that with a given maximum codeword length, the block error rate (BLER) performance of the LDPC codes is increased because the average codeword length is increased with the CBS scheme of particular embodiments.
(14) The following description sets forth numerous specific details. It is understood, however, that embodiments may be practiced without these specific details. In other instances, well-known circuits, structures and techniques have not been shown in detail in order not to obscure the understanding of this description. Those of ordinary skill in the art, with the included descriptions, will be able to implement appropriate functionality without undue experimentation.
(15) References in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to implement such feature, structure, or characteristic in connection with other embodiments, whether or not explicitly described.
(16) Particular embodiments are described with reference to
(17)
(18) In general, wireless devices 110 that are within coverage of network node 120 (e.g., within cell 115 served by network node 120) communicate with network node 120 by transmitting and receiving wireless signals 130. For example, wireless devices 110 and network node 120 may communicate wireless signals 130 containing voice traffic, data traffic, and/or control signals. A network node 120 communicating voice traffic, data traffic, and/or control signals to wireless device 110 may be referred to as a serving network node 120 for the wireless device 110. Communication between wireless device 110 and network node 120 may be referred to as cellular communication. Wireless signals 130 may include both downlink transmissions (from network node 120 to wireless devices 110) and uplink transmissions (from wireless devices 110 to network node 120).
(19) Each network node 120 may have a single transmitter 140 or multiple transmitters 140 for transmitting signals 130 to wireless devices 110. In some embodiments, network node 120 may comprise a multi-input multi-output (MIMO) system. Similarly, each wireless device 110 may have a single receiver or multiple receivers for receiving signals 130 from network nodes 120 or other wireless devices 110.
(20) Wireless signals 130 may be encoded with LDPC codes such as those described with respect to
(21) In wireless network 100, each network node 120 may use any suitable radio access technology, such as long term evolution (LTE), LTE-Advanced, UMTS, HSPA, GSM, cdma2000, NR, WiMax, WiFi, and/or other suitable radio access technology. Wireless network 100 may include any suitable combination of one or more radio access technologies. For purposes of example, various embodiments may be described within the context of certain radio access technologies. However, the scope of the disclosure is not limited to the examples and other embodiments could use different radio access technologies.
(22) As described above, embodiments of a wireless network may include one or more wireless devices and one or more different types of radio network nodes capable of communicating with the wireless devices. The network may also include any additional elements suitable to support communication between wireless devices or between a wireless device and another communication device (such as a landline telephone). A wireless device may include any suitable combination of hardware and/or software. For example, in particular embodiments, a wireless device, such as wireless device 110, may include the components described with respect to
(23) In particular embodiments, a code block segmentation (CBS) scheme for NR is based on a maximum codeword length Nmax (supported by LDPC decoder hardware) and minimum code rate of the LDPC encoder. In general, large code blocks may be used if the desired code rate is fairly high (e.g., rate ⅓ or higher) while the transport block may be divided into shorter segments if the desired code rate is lower. The size of the code blocks is calculated from the maximum codeword length, the maximum allowed code block length, and the desired code rate.
(24) The following notations are used herein: TBS: Transport block size L.sub.TB: Number of CRC bits attached on transport block level L.sub.CB: Number of CRC bits attached on code block level K.sub.max: Maximum number of information bits supported by the channel code K: Code block size R: Desired code rate R.sub.min: Minimum code rate supported by LDPC encoder via code extension for information block size K<K.sub.max, as long as N.sub.max is not exceeded. N.sub.max: Maximum codeword length supported by the LDPC decoder hardware N.sub.CB: Number of code blocks in this transmission N.sub.sys,punc: Number of punctured systematic information bits K.sub.CB,max: Maximum code block size to use in the code block segmentation K.sub.CB,j: Size of code block j before code-block level CRC bits are attached
(25) Based on these notations, the number of code blocks and the code block sizes are calculated as follows: 1) Calculate the minimum code rate R.sub.min,Kmax that can be supported for the largest code block size K.sub.max,
(26)
In principle, N.sub.sys,punc depends on K and the Z-value used for that K. For simplicity, N.sub.sys,punc may be calculated for Z.sub.max instead of the actual Z. In the above, the desired code rate R is calculated based on several factors including: (a) transport block size TBS; (b) allocated physical resource blocks in time-frequency domain; (c) the modulation order indicated for the given TBS; (d) the number of MIMO layers indicated for the given TB. 3) If TBS+L.sub.TB>K.sub.CB,max+L.sub.CB, the number of code blocks and the size of each code block, before the code-block level CRC is attached, is determined by
(27)
(28)
(29)
(30) If TBS+L.sub.TB≤K.sub.CB,max+L.sub.CB, then code block segmentation is not required, thus:
N.sub.CB=.sup.1
K.sub.CB,1=TBS+L.sub.TB
(31)
(32) In particular embodiments, having max(R.sub.min, R), instead of R alone, accounts for the minimum code rate R.sub.min that can be achieved through code extension for the specific LDPC code. Any code rates lower than R.sub.min may be achieved through repetition and may therefore not be included in the calculation of the codeword length. After encoding, but before transmission, rate-matching (for example based on a circular buffer as in LTE) may be used to achieve the desired code rate and block length.
(33) Some embodiments use repetition to reduce the number of code blocks. For example, some embodiments use
C.Math.K.sub.CB,max<TBS+L.sub.TB≤C.Math.K.sub.CB,max+ΔK
where C is an integer and AK is a threshold which is small compared to K.sub.CB,max. This results in C+1 code blocks with the code block segmentation method described above, because the desired code rate R cannot be achieved through code expansion within C code blocks. However, if a small amount of repetition, instead of code extension, is allowed for cases like this, the number of code blocks can be reduced to C instead of C+1 and the code block length may be larger, resulting in improved BLER performance. Example 3 described in more detail below is an example of performing repetition to reduce the number of code blocks and thereby increase the code block size.
(34) Particular embodiments may calculate the total codeword length as seen by a layered decoder. For quasi-cyclic LDPC codes, a layered decoder handles blocks of Z bits in parallel. If the number of parity bits or information bits is not a factor of Z, the decoder may have to handle additional punctured or shortened bits to make the number of bits a factor of Z. This may be accounted for already in the code block segmentation method or can simply be ignored and instead handled by using repetition of some bits to ensure that the total codeword length does not exceed N.sub.max.
(35) To ensure that the number of information bits plus shortened bits do not exceed the allowed number of information bits calculated from N.sub.max and R, K.sub.CB,max may be decreased to the largest possible value which can be written as an integer times Z. By doing so, the probability that N.sub.max is exceeded is reduced and it is less likely that repetition is needed to achieve the desired code rate.
(36) Another alternative is to increase K.sub.CB,max to the next value which can be written as an integer times Z. This increases the probability that repetition is needed, but also allows larger code blocks that may result in better BLER performance.
(37) The following examples describe in more detail the CBS method of particular embodiments. While 24-bit TB-level CRC, L.sub.TB=24, and 12-bit code-block level CRC, L.sub.CB=12, is assumed in the examples below, it is understood that other values of L.sub.TB and L.sub.CB may be used by other embodiments and that the same methodology can be applied.
(38) Example 1 is an example where code block segmentation is not needed. Let the transport block size be TBS=5000 bits. To the transport block, L.sub.TB=24 CRC bits are attached. The desired code rate is R= 1/10 for the given transport block. In terms of LDPC code construction, the minimum code rate achieved through code extension is R.sub.min=⅕. The maximum codeword length handled by the decoder is N.sub.max=30000 bits and the number of punctured systematic information bits is N.sub.sys,punc=100. Furthermore, the decoder is only provisioned to handle a maximum of K.sub.max=8192 information bits, due to a limitation of the maximum Z. L.sub.CB=12 CRC bits should be attached to each code block. 1) The minimum code rate R.sub.min,Kmax that can be supported for the largest code block size K.sub.max is
(39)
K.sub.CB,max=max(R.sub.min,R).Math.(N.sub.max−N.sub.sys,punc)−L.sub.CB=max(0.2,0.1)
(30000−100)−12=5968 3) TBS L.sub.TB=5000+24=5024<K.sub.CB,max+L.sub.CB=5968+12=5980 and no code block segmentation is performed.
(40) Example 2 is similar to example 1, but describes a case where code block segmentation is needed. In example 2, let the transport block size be TBS=60000 bits. To the transport block, L.sub.TB=24 CRC bits are attached. The desired code rate R= 1/10 and the minimum code rate achieved through code extension is R.sub.min=⅕. The maximum codeword length handled by the decoder is N.sub.max=30000 bits, the number of punctured systematic information bits is N.sub.sys,punc=100 and K.sub.max=8192 information bits. L.sub.CB=12 CRC bits should be attached to each code block. 1) The minimum code rate R.sub.min,Kmax that can be supported for the largest code block size K.sub.max iS
(41)
K.sub.CB,max=MaX(R.sub.min,R).Math.(N.sub.max−N.sub.sys,punc)−L.sub.CB=max(0.2,0.1).Math.(30000−100)−12=5968 3) TBS+L.sub.TB=60000+24=60024>K.sub.CB,max+L.sub.CB=5968+12=5980 which indicates that code block segmentation should be performed. The number of code blocks and the size of each code block, before the code-block level CRC is attached, is determined by
(42)
(43)
(44)
(45) Example 3 is an example where code block segmentation can be avoided through the use of repetition. Let the transport block size be TBS=7000 bits. To the transport block, L.sub.TB=24 CRC bits are attached. The desired code rate R=0.234 and the minimum code rate achieved through code extension is R.sub.min=⅕. The maximum codeword length handled by the decoder is N.sub.max=30000 bits, the number of punctured systematic information bits is N.sub.sys,punc=100 and K.sub.max=8192 information bits. L.sub.CB=12 CRC bits should be attached to each code block. Repetition may be used to reduce the number of segments if the constraint is fulfilled for ΔK=50. 1) The minimum code rate R.sub.min,Kmax that can be supported for the largest code block size K.sub.max is
(46)
K.sub.CB,max=max(R.sub.min,R).Math.(N.sub.max−N.sub.sys,punc)−L.sub.CB=max(0.2,0.234).Math.(30000−100)−12=6985 TBS+L.sub.TB=7000+24=7024>K.sub.CB,max+L.sub.CB=6985+12=6997 which indicates that code block segmentation must be performed. However, checking the constraint
C.Math.K.sub.CB,max<TBS+L.sub.TB−L.sub.CB≤C.Math.K.sub.CB,max+ΔK finds that for C=1, the constraint is fulfilled and repetition may be used to avoid code block segmentation. The number of code blocks and the size of each code block, before the code-block level CRC is attached, is determined by
(47)
(48)
N.sub.rep=K.sub.CB−max(R.sub.min,R).Math.(N.sub.max−N.sub.sys,punc)=7024−0.234.Math.29900≈27.
(49) In particular embodiments, each CB group (CBG) may be attached with a predefined number of L.sub.CBG CBG-level CRC bits. For NR, it may be possible to attach CRC on code-block group level in addition to, or instead of, attaching CRC on code-block level. A more general description of the code block segmentation method of particular embodiments accounts for both L.sub.TB CRC bits added on TB-level, L.sub.CB CRC bits added on code-block level and L.sub.CBG CRC bits added on code-block group level. The L.sub.CBG CRC bits added on code-block group level are attached to each of a maximum of N.sub.CBG code-block groups. Note that setting N.sub.CBG=0 and L.sub.CBG=0 is equivalent to the CBS approach described earlier. Step 1) for calculation of the minimum code rate, R.sub.min,Kmax is the same as in the less general description above, because this is independent of the CRC attachments. Step 2) for calculation of the maximum code block size, K.sub.CBmax to use in code block segmentation is also performed as before. The L.sub.CB CRC bits that are attached on code-block level are accounted for in the calculation of K.sub.CBmax, because these CRC bits must be included in each code block. The L.sub.TB CRC bits added on TB-level and the L.sub.CBG CRC bits added on code-block group level are accounted for in step 3) below 3) If TBS+L.sub.TB+N.sub.CBG.Math.L.sub.CBG>K.sub.CB,max+L.sub.CB, the number of code blocks and the size of each code block, before the code-block level CRC is attached, is determined by the following. a. Calculate the number of CBs:
(50)
(51)
(52) Otherwise, each CBG is composed of a single CB. That is, CBG is degenerated to be equal to one CB. Attaching CRC bits per CBG degenerates to attaching CRC bits per CB. In the general case, L.sub.CBG L.sub.CB CRC bits are added to each code block. It is likely, however, that either L.sub.CBG or L.sub.CB is set to zero for such a case.
(53) If TBS+L.sub.TB+N.sub.CBG.Math.L.sub.CBG≤K.sub.CB,max+L.sub.CB, code block segmentation is not required, thus
N.sub.CB=1
K.sub.CB,1=TBS+L.sub.TB+L.sub.CBG
(54) In the case of no code block segmentation, the code-block group CRC bits may or may not be attached to the transport block.
(55) Particular wireless devices may vary in complexity. The complexity and chip area needed for the LDPC decoder is connected to the maximum codeword length that the hardware is provisioned for. It is therefore likely that different wireless device categories (or UE categories) may have hardware provisioned for different maximum codeword length N.sub.max. The minimum code rate R.sub.min that can be achieved through code extension may also vary between wireless device categories. For example, an mMTC UE may have a high R.sub.niin, while a URLLC UE may have a very low R.sub.min. These parameters are already accounted for in the code block segmentation embodiments described herein, which makes it simple to apply on different UE categories.
(56) Particular embodiments may include methods in a transmitter. The examples and embodiments described above may be generally represented by the flowchart in
(57)
(58) The method begins at step 512, where the wireless transmitter, such as network node 120 or wireless device 110, receives a plurality of bits for a wireless transmission. For example, a PHY layer of network node 120 may receive information bits from a higher protocol layer for transmission to wireless device 110.
(59) At step 514, the wireless transmitter determines a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code. For example, network node 120 may determine the code block size based on any of the embodiments, examples, and equations described above (e.g., determination of K.sub.CB,max).
(60) In particular embodiments, the design parameters of the channel code limit the maximum code block size to Kmax for any code rate. In some embodiments, Nmax limits the maximum code block size according to K.sub.CB,max=max(R.sub.min, R).Math.(N.sub.max−N.sub.sys,punc)−L.sub.CB.
(61) At step 516, the wireless transmitter segments the plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size. For example, network node 120 may segment the received bits into two code blocks according to any of the embodiments or examples described above (e.g., determination of N.sub.CB).
(62) In particular embodiments, the segmenting the plurality of bits includes a threshold AK for the number of bits with which the TBS+TB-level CRC bits is allowed to exceed the number of code blocks times maximum code block size.
(63) At step 518, the wireless transmitter transmits the one or more code block segments to a wireless receiver. For example, network node 120 may transmit the code block segments to wireless device 110.
(64) Modifications, additions, or omissions may be made to method 500. Additionally, one or more steps in method 500 of
(65)
(66) Particular examples of a wireless device include a mobile phone, a smart phone, a PDA (Personal Digital Assistant), a portable computer (e.g., laptop, tablet), a sensor, a modem, a machine type (MTC) device/machine to machine (M2M) device, laptop embedded equipment (LEE), laptop mounted equipment (LME), USB dongles, a device-to-device capable device, a vehicle-to-vehicle device, or any other device that can provide wireless communication. The wireless device includes transceiver 610, processing circuitry 620, memory 630, and power source 640. In some embodiments, transceiver 610 facilitates transmitting wireless signals to and receiving wireless signals from wireless network node 120 (e.g., via an antenna), processing circuitry 620 executes instructions to provide some or all of the functionality described herein as provided by the wireless device, and memory 630 stores the instructions executed by processing circuitry 620. Power source 640 supplies electrical power to one or more of the components of wireless device 110, such as transceiver 610, processing circuitry 620, and/or memory 630.
(67) Processing circuitry 620 includes any suitable combination of hardware and software implemented in one or more integrated circuits or modules to execute instructions and manipulate data to perform some or all of the described functions of the wireless device. In some embodiments, processing circuitry 620 may include, for example, one or more computers, one more programmable logic devices, one or more central processing units (CPUs), one or more microprocessors, one or more applications, and/or other logic, and/or any suitable combination of the preceding. Processing circuitry 620 may include analog and/or digital circuitry configured to perform some or all of the described functions of wireless device 110. For example, processing circuitry 620 may include resistors, capacitors, inductors, transistors, diodes, and/or any other suitable circuit components.
(68) Memory 630 is generally operable to store computer executable code and data. Examples of memory 630 include computer memory (e.g., Random Access Memory (RAM) or Read Only Memory (ROM)), mass storage media (e.g., a hard disk), removable storage media (e.g., a Compact Disk (CD) or a Digital Video Disk (DVD)), and/or or any other volatile or non-volatile, non-transitory computer-readable and/or computer-executable memory devices that store information.
(69) Power source 640 is generally operable to supply electrical power to the components of wireless device 110. Power source 640 may include any suitable type of battery, such as lithium-ion, lithium-air, lithium polymer, nickel cadmium, nickel metal hydride, or any other suitable type of battery for supplying power to a wireless device. In particular embodiments, processing circuitry 620 in communication with transceiver 610 determines a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code; and segments a plurality of bits for wireless transmission into one or more code block segments such that no one of the one more or more code block segments is larger than the determined maximum code block size.
(70) Other embodiments of the wireless device may include additional components (beyond those shown in
(71)
(72) Receiving module 650 may perform the receiving functions of wireless device 110. For example, receiving module 650 may receive a plurality of bits for a wireless transmission, according to any of the examples or embodiments described above (e.g., step 512 of
(73) Determining module 652 may perform the determining functions of wireless device 110. For example, determining module 652 may determine a maximum code block size for a transmission based on any of the embodiments or examples described above (e.g., step 514 of
(74) Segmenting module 654 may perform the segmenting functions of wireless device 110. For example, segmenting module 654 may segment a plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size, according to any of the examples or embodiments described above (e.g., step 516 of
(75) Transmitting module 656 may perform the transmitting functions of wireless device 110. For example, transmitting module 656 may transmit the one or more code block segments to a wireless receiver, such as network node 120, according to any of the examples or embodiments described above (e.g., step 518 of
(76)
(77) Network node 120 can be an eNodeB, a nodeB, gNB, a base station, a wireless access point (e.g., a Wi-Fi access point), a low power node, a base transceiver station (BTS), a transmission point or node, a remote RF unit (RRU), a remote radio head (RRH), or other radio access node. The network node includes at least one transceiver 710, processing circuitry 720, at least one memory 730, and at least one network interface 740. Transceiver 710 facilitates transmitting wireless signals to and receiving wireless signals from a wireless device, such as wireless devices 110 (e.g., via an antenna); processing circuitry 720 executes instructions to provide some or all of the functionality described above as being provided by a network node 120; memory 730 stores the instructions executed by processing circuitry 720; and network interface 740 communicates signals to backend network components, such as a gateway, switch, router, Internet, Public Switched Telephone Network (PSTN), controller, and/or other network nodes 120. Processing circuitry 720 and memory 730 can be of the same types as described with respect to processing circuitry 620 and memory 630 of
(78) In some embodiments, network interface 740 is communicatively coupled to processing circuitry 720 and refers to any suitable device operable to receive input for network node 120, send output from network node 120, perform suitable processing of the input or output or both, communicate to other devices, or any combination of the preceding. Network interface 740 includes appropriate hardware (e.g., port, modem, network interface card, etc.) and software, including protocol conversion and data processing capabilities, to communicate through a network. In particular embodiments, processing circuitry 720 in communication with transceiver 710 determines a maximum code block size for the transmission based on code rate, maximum code word size Nmax, and design parameters of the channel code; and segments a plurality of bits for wireless transmission into one or more code block segments such that no one of the one more or more code block segments is larger than the determined maximum code block size.
(79) Other embodiments of network node 120 include additional components (beyond those shown in
(80)
(81) Receiving module 750 may perform the receiving functions of network node 120. For example, receiving module 750 may receive a plurality of bits for a wireless transmission, according to any of the examples or embodiments described above (e.g., step 512 of
(82) Determining module 752 may perform the determining functions of network node 120. For example, determining module 752 may determine a maximum code block size for a transmission based on any of the embodiments or examples described above (e.g., step 514 of
(83) Segmenting module 754 may perform the segmenting functions of network node 120. For example, segmenting module 754 may segment a plurality of bits into one or more code block segments such that no one of the one or more code block segments is larger than the determined maximum code block size, according to any of the examples or embodiments described above (e.g., step 516 of
(84) Transmitting module 756 may perform the transmitting functions of network node 120. For example, transmitting module 756 may transmit the one or more code block segments to a wireless receiver, such as wireless device 110, according to any of the examples or embodiments described above (e.g., step 518 of
(85) Modifications, additions, or omissions may be made to the systems and apparatuses disclosed herein without departing from the scope of the invention. The components of the systems and apparatuses may be integrated or separated. Moreover, the operations of the systems and apparatuses may be performed by more, fewer, or other components. Additionally, operations of the systems and apparatuses may be performed using any suitable logic comprising software, hardware, and/or other logic. As used in this document, “each” refers to each member of a set or each member of a subset of a set.
(86) Modifications, additions, or omissions may be made to the methods disclosed herein without departing from the scope of the invention. The methods may include more, fewer, or other steps. Additionally, steps may be performed in any suitable order.
(87) Although this disclosure has been described in terms of certain embodiments, alterations and permutations of the embodiments will be apparent to those skilled in the art. Accordingly, the above description of the embodiments does not constrain this disclosure. Other changes, substitutions, and alterations are possible without departing from the spirit and scope of this disclosure, as defined by the claims below.
(88) Abbreviations used in the preceding description include: 3GPP Third Generation Partnership Project BLER Block Error Rate BTS Base Transceiver Station CBG Code Block Group CBS Code Block Segmentation D2D Device to Device DL Downlink eNB eNodeB FDD Frequency Division Duplex LDPC low-density Parity Check LTE Long Term Evolution M2M Machine to Machine MCS Modulation and Coding Scheme MIMO Multi-Input Multi-Output MTC Machine Type Communication NR New Radio OFDM Orthogonal Frequency Division Multiplex PCM Parity-Check Matrix PRB Physical Resource Block RAN Radio Access Network RAT Radio Access Technology RB Resource Block RBS Radio Base Station RE Resource Element RNC Radio Network Controller RRC Radio Resource Control RRH Remote Radio Head RRU Remote Radio Unit SC-FDMA Single Carrier-Frequency Division Multiple Access TDD Time Division Duplex TBS Transport Block Size TTI Transmission Time Interval UE User Equipment UL Uplink URLLC Ultra-Reliable Low Latency Communication UTRAN Universal Terrestrial Radio Access Network WAN Wireless Access Network