1. Technical Field
The present disclosure relates generally to communication systems; and, more particularly, to determining signal to noise ratio (SNR) and/or SNR margin of communications within such communication systems.
2. Description of Related Art
Data communication systems have been under continual development for many years. The primary goal within such communication systems is to transmit information successfully between devices. Unfortunately, many things can deleteriously affect signals transmitted within such systems resulting in degradation of or even complete failure of communication. Examples of adverse effects include interference and noise that may be caused by various sources including other communications, low-quality links, degraded or corrupted interfaces and connectors, etc.
Some communication systems use forward error correction (FEC) coding and/or error correction code (ECC) coding to increase the reliability and the amount of information that may be transmitted between devices. When a signal incurs one or more errors during transmission, a receiver device can employ the FEC or ECC coding to try to correct those one or more errors.
A continual and primary directive in this area of development has been to try continually to lower the signal to noise ratio (SNR) required to achieve a given bit error ratio (BER) or symbol error ratio (SER) within a communication system. The Shannon limit is the theoretical bound for channel capacity for a given modulation and code rate. The ideal goal has been to try to reach Shannon's channel capacity limit in a communication channel. Shannon's limit may be viewed as being the data rate per unit of bandwidth (i.e., spectral efficiency) to be used in a communication channel, having a particular SNR, where transmission through the communication channel with arbitrarily low BER or SER is achievable.
In some instances, it is desirable to determine the SNR of a signal when transmitted from a first communication device compared to the SNR of that same signal when received at a second communication device. In other instances, it may be desirable to determine the SNR of a signal received at a communication device in comparison to a lowest SNR at which acceptable performance is achieved. Generally, this can be referred to as SNR margin. Prior art approaches to determine SNR margin can be complex, computationally costly, and inefficient. Prior art approaches to determine SNR margin are performed in the front end of the device (e.g., analog front end (AFE), demodulator, etc.). As such, such prior art approaches can be highly inaccurate based on inaccurate SNR measurements. There continues to exist a great deal of room for improvement in determining SNR margin within communication systems.
The various communication links within the one or more network segments 116 may be implemented using any of a variety of communication media including communication links implemented as wireless, wired, optical, satellite, microwave, and/or any combination thereof, etc. communication links. Also, in some instances, communication links of different types may cooperatively form a connection pathway between any two communication devices. Considering one possible example, a communication pathway between devices 110 and 112 may include some segments of wired communication links and other segments of optical communication links. Note also that the devices 110-114 may be of a variety of types of devices including stationary devices, mobile devices, portable devices, etc. and may support communications for any of a number of services or service flows including data, telephony, television, Internet, media, synchronization, etc.
In an example of operation, device 110 includes a communication interface to support communications with one or more of the other devices 112-114. This communication may be bidirectional/to and from the one or more of the other devices 112-114 or unidirectional (or primarily unidirectional) from the one or more of the other devices 112-114.
In an example, device 110 includes a communication interface and a processor to perform functions including receiving and transmitting of signals, encoding and decoding of signals, determining SNR margin based on processing of one or more signals, etc. From certain perspectives, the processor performs operations including directing the function of the communication interface for transmitting and receiving signals. The communication interface may be implemented to perform a variety of functions including digital to analog conversion, analog-to-digital conversion, frequency conversion (up or down), scaling, filtering, etc. and/or any other functions to generate signals suitable for transmission via one or more communication channels and/or front-end processing of signals received via the one or more communication channels for other channels. Generally speaking, analog front end (AFE) related operations are performed within the communication interface.
The device 110 operates to receive forward error correction (FEC) code and/or error correction code (ECC) coded signals (e.g., generally referred to as signals) from another device, such as device 112. The device 110 then performs decoding of those signals to make estimates of information encoded therein. When performing an iterative decoding process on those signals, the device 110 determines an operational error check rate based on error check failure of at least one of the signals after performing a predetermined number of decoding iterations. For example, considering a situation where a first number of decoding iterations successfully decode the signals (e.g., e.g., N1=15 decoding iterations), the device 110 determines an operational error check rate based on error check failure of any of the signals after performing less than that first number of decoding iterations, N1 (e.g., a maximum number of decoding iterations). In one instance, the operational error check rate is based on error check failure after performing only a second number, N2, decoding iterations, where N2 is a positive integer that is less than N1 (e.g., N1=15 and N2=8). The device 110 then determines a signal to noise ratio (SNR) margin of the device by applying the determined operational error check rate to the characterization of the device that relates error check rate and SNR. For example, information that characterizes the device 110 may be known beforehand. By determining the operational error check rate based on error check failure as determined during decoding of at least one of the received signals at an iteration count less than the number of decoding iterations needed to successfully decode the signals, the current operating SNR of the device 110 may be determined. The SNR margin is then the difference between the SNR of the device 110 and is determined based on the operational error check rate and the targeted operating SNR (e.g., at a performance of SNR=30 dB).
In an example, consider that 2 of the 1000 received signals fails to decode properly after performing N2=8 decoding iterations, and where N1=15 decoding iterations results in successful decoding of all 1000 received signals. This would then provide an error check failure total of 2 and a corresponding operational error check rate of 2×10−3 or 0.002 (e.g., the error check failure total, 2, divided by the total number of received signals, 1000). This operational error check rate (e.g., the error check failure total relative to the number of received signals or the error check failure total divided by the number of received signals) is then applied to a characterization of the device 110 that relates error check rate and SNR. This will result in determining the SNR of the device 110. The SNR margin is then the difference between this determined SNR of the device 110 and a lowest SNR associated with a targeted performance. Considering some possible values, if the determined SNR of the device 110 is 35 dB, and the lowest SNR associated with a targeted performance is 30 dB, then the SNR margin would be 5 dB. Alternatively, if the determined SNR of the device 110 is 34 dB, and assuming the same lowest SNR associated with the targeted performance, then the SNR margin would be 4 dB.
Note that SNR margin of the device may be determined using FEC code and/or ECC decoding statistics based on the operations that are performed during decoding of coded signals. With very little additional complexity, appropriate tracking of certain information during the decoding processing allows the device 110 to determine its SNR and its SNR margin.
Also, note that prior art approaches may try to determine SNR margin based on the front end of a device (e.g., based on statistics related to the analog front end (AFE), the demodulator, etc.). As such, those SNR margin calculations and determinations may be relatively inaccurate. For example, this inaccuracy may be attributed, at least in part, to the fact that such approaches may not deal directly with BER or BLER. As a consequence, decisions made to adapt operation based on SNR margin determination performed using prior techniques may be made in error. As an example, if the accuracy of that SNR margin calculation using a prior art technique is ±3 dB, then adjustment of any operational parameters will take into account this possible inaccuracy. As such, it is likely that operational decisions be made to ensure that an adequate SNR margin will remain.
In contrast, a device implemented as described herein uses statistics generated during the decoding processing itself to determine SNR margin. In other words, by using the FEC code and/or ECC decoding statistics themselves, the device 110 can generate a very highly accurate estimate of SNR and SNR margin of the device 110. As such, adjustment of one or more operational parameters of the device 110 and/or another device (e.g., device 112) in communication with the device 110 can be made with a firm confidence on the determined SNR margin. Such adjustment can then be made so that subsequent operation may be made with a relatively small SNR margin. Alternatively, when a relatively large SNR margin is determined, and with such accurate knowledge related to the determined relatively large SNR margin, when an adequate SNR margin is available, the operational parameters may be adjusted to capitalize on that SNR margin.
Different adaptation of one or more operational parameters may be performed based on information related to SNR margin. In one example, when operation is performed with a relatively large SNR margin, then power may be adjusted to reduce that SNR margin. In one possible implementation, a receiver device, which calculates the SNR margin, transmits information related to the SNR margin to a transmitter device. When there is a sufficiently large SNR margin, the transmitter device may reduce transmit power for use in subsequent communications. In an alternative implementation, the transmitter device may maintain the same transmit power yet increase the modulation used for subsequent communications (e.g., increase the number of constellation points used in one or more of the symbols to be transmitted). Any of a number of different operational parameters may be adjusted based on SNR margin for a transmitter and/or receiver device that in communication with one another via one or more communication links.
Generally, within a communication system and/or communication device, the operating signal to noise ratio (SNR) margin may be defined as a function of the current operating SNR and the targeted operating SNR as follows: SNR margin=current operating SNR−targeted operating SNR
If the communication device and/or system has information indicating that it has a certain operating SNR margin, it can adapt its operation accordingly. For example, the communication system and/or one or more communication devices may change the modulation order (e.g., from a relatively lower order modulation to a relatively higher order modulation, such as from 16 quadrature amplitude modulation (QAM) to 256 QAM) to change (increase) the system data throughput).
Note that, when the SNR margin is less or diminishing, the communication system and/or one or more of the communication devices may change the modulation order from a relatively higher order modulation to a relatively lower order modulation, such as from 16 quadrature amplitude modulation (QAM) to quadrature phase shift keying (QPSK) of 4-QAM to change (reduce) the system data throughput. Also, the communication system and/or one or more of the communication devices may change (e.g., reduce) transmit power to save power. For another example, the communication system and/or one or more of the communication devices may change the transmit power used for communications.
Note also that any of a number of different types of FEC code and/or ECC may be used. Depending on the particular code that is used, different characteristics related to that code may be used to determine the operational error check rate (e.g., the error check failure total relative to a number of coded signals). In an example of operation, device 110 performs encoding of one or more bits to generate one or more coded bits used to generate the modulation data (or generally, data) using any desired one or more FEC codes and/or ECCs to generate one or more coded bits. Examples of FEC code and/or ECC may include turbo code, convolutional code, turbo trellis coded modulation (TTCM), low density parity check (LDPC) code, Reed-Solomon (RS) code, BCH (Bose and Ray-Chaudhuri, and Hocquenghem) code, etc. The one or more coded bits may then undergo modulation or symbol mapping to generate modulation symbols. The modulation symbols may include data intended for one or more recipient devices. Note that such modulation symbols may be generated using any of various types of modulation coding techniques. Examples of such modulation coding techniques may include binary phase shift keying (BPSK), quadrature phase shift keying (QPSK), 8-phase shift keying (PSK), 16 quadrature amplitude modulation (QAM), 32 amplitude and phase shift keying (APSK), etc., uncoded modulation, and/or any other desired types of modulation including higher ordered modulations that may include even greater number of constellation points (e.g., 1024 QAM, etc.) in single-carrier (SC) systems or multiple-carrier systems (e.g., orthogonal frequency division multiplexing (OFDM), orthogonal frequency division multiple access (OFDMA), etc.).
Also, in conjunction with or in other examples, device 110 may use other types of decoding statistics to determine SNR margin. In one implementation, device 110 uses an average number of decoding iterations across a number of decoded signals to determine the SNR margin. In another implementation, device 110 uses an FEC code and/or ECC corrected bit rate to determine the SNR margin. In another implementation, device 110 uses a determined operational error check rate (e.g., the error check failure total relative to a number of coded signals such that the error check failure total) is determined based on a number of decoding iterations that is fewer than a maximum number of decoding iterations. Device 110 may be implemented to use any one or more of these various approaches to determine SNR margin. Once the SNR margin is known, device 110 may adjust any one or more of its own operational parameters and/or communicate information to another device, such as device 112, so that the other device may adjust any one or more of its operational parameters.
The cable headend transmitter 130 may provide operation of a cable modem termination system (CMTS) 140a. For example, the cable headend transmitter 130 may perform such CMTS functionality, or a CMTS may be implemented separately from the cable headend transmitter 130 (e.g., as shown by reference numeral 140). The CMTS 140 can provide network service (e.g., Internet, other network access, etc.) to any number of cable modems (shown as CM 1, CM 2, and up to CM n) via a cable modem (CM) network segment 199. The cable network segment 198 and the CM network segment 199 may be part of a common network or common networks. The cable modem network segment 199 couples the cable modems 1-n to the CMTS (shown as 140 or 140a). Such a cable system (e.g., cable network segment 198 and/or CM network segment 199) may generally be referred to as a cable plant and may be implemented, at least in part, as a hybrid fiber-coaxial (HFC) network (e.g., including various wired and/or optical fiber communication segments, light sources, light or photo detection complements, etc.).
A CMTS 140 (or 140a) is a component that exchanges digital signals with cable modems 1-n on the cable modem network segment 199. Each of the cable modems is coupled to the cable modem network segment 199, and a number of elements may be included within the cable modem network segment 199. For example, routers, splitters, couplers, relays, and amplifiers may be contained within the cable modem network segment 199. Generally speaking, downstream information flows from the CMTS 140 to the connected cable modems (e.g., CM 1, CM2, etc.), and upstream information flows from the cable modems to the CMTS 140.
Any of the various devices within this diagram may be implemented to include a processor and communication interface to generate and transmit signals to any one of the other devices and to receive and interpret signals from any one of the other devices. Considering one of the cable modems as an example, CM 1 may be implemented to include a processor and a communication interface. The processor receives, via the communication interface, FEC coded signals from CMTS 140. The processor then iteratively decodes the FEC coded signals to make estimates of information encoded therein. The processor also determines an error check failure total based on error check failure of at least one of the FEC coded signals after performing a predetermined number of decoding iterations. For example, considering an embodiment in which a maximum of 10 decoding iterations is performed, then the processor may determine the error check failure total based on error check failure of those of the FEC coded signals that are not successfully decoded after performing 5 decoding iterations (e.g., where a maximum number of decoding iterations is N1=10, and the less than maximum number of decoding iterations used to determine the error check failure total is N2=5). The processor then applies the error check failure total relative to the number of coded signals to determine an operational error check rate (e.g., the error check failure total divided by the number of coded signals). The processor then applies the operational error check rate to a characterization of the CM 1 that relate error check rate in SNR to determine the SNR margin of the CM 1. Then, the CM 1 may adjust any one or more of its operational parameters based on knowledge of the SNR margin. Alternatively, or in conjunction with, the CM 1 may communicate information of the SNR margin to the CMTS 140 so that the CMTS 140 may adjust any one or more of its operational parameters based on the knowledge of the SNR margin.
In an example of operation, device 110's processor 230 receives, via the communication interface 220, a plurality of forward error correction (FEC) coded signals from device 112. The processor 230 then iteratively decodes the plurality of FEC coded signals to make estimates of information encoded therein. The processor 230 then determines an error check failure total based on error check failure of at least one of the plurality of FEC coded signals after performing a predetermined number of decoding iterations. The processor 230 then applies the error check failure total relative to the number of coded signals to determine an operational error check rate (e.g., the error check failure total divided by the number of coded signals). For example, if a maximum number of decoding iterations is N1, then the processor 230 determines how many of the signals do not pass error check failure after performing the predetermined number of decoding iterations, N2, which is less than N1. The processor 230 then applies this operational error check rate to a characterization of the communication device that relates error check rate and SNR.
Note that device 110 may be implemented to operate as any one or more of a satellite communication device, a wireless communication device, a wired communication device, a fiber-optic communication device, or a mobile communication device and implemented and/or operative within any one or more communication systems including a satellite communication system, a wireless communication system, a wired communication system, a fiber-optic communication system, or a mobile communication system.
The device 110 may be configured to determine different SNR margins at different times based on decoding statistics associated with different groups of signals. If desired, decoding statistics associated with different numbers of signals may be used at different times and over different time periods to determine SNR margin. For example, in a relatively static or predictable communication system (e.g., a wire based, cable based, etc. communication system), decoding statistics associated with a relatively large number of signals may be used. Alternatively, in a more dynamic and changing communication system (e.g., a wireless, cellular, etc. communication system), decoding statistics associated with a relatively small number of signals may be used at a time. Also, note that decoding statistics associated with a first number of signals may be used to determine a first SNR margin and decoding statistics associated with a second number of signals may be used to determine a second SNR margin.
The device 110 includes or has access to information that characterizes the device 110 and relates error check rate and SNR. This characterization may be performed and/or provided ‘a priori’, namely, before the device 110 is deployed and implemented within a communication system. Note also that different devices may perform different decoding operations and have different characterizations. If desired, the characterization of the device may be mapped to a standardized curve agreed upon among a number of device manufacturers. This way, different devices can associate their specific characterization to a standardized curve. Such comparison and application would then be made relative to such a standardized curve.
In such an instance, this error check failure total relative to the number of received signals provides the operational error check rate. Then, the operational error check rate is applied to a standardized curve that represents a characterization of the device 110 that relates error check rate and SNR. This will result in determining the current operating SNR of the device 110. The SNR margin is then the difference between this determined SNR of the device 110 and the targeted operating SNR. Considering some possible values, if the determined SNR of the device 110 is 33.2 dB, and the targeted operating SNR is 30 dB, then the SNR margin would be 3.2 dB. Alternatively, if the determined SNR of the device 110 is 31 dB, and assuming the same targeted operating SNR, then the SNR margin would be 1 dB.
Note also device 110 may be implemented to use different numbers of maximum decoding iterations and predetermined number of fewer than maximum number of decoding iterations may be used. For example, during a first period of time or when processing a first group of signals, device 110 performs a first maximum of N1=16 decoding iterations and N2=8 decoding iterations (e.g., a first predetermined number of decoding iterations that is less than the first maximum number of decoding iterations). Then, during a second period of time or when processing a second group of signals, device 110 performs a second maximum of N1=10 decoding iterations and N2=5 decoding iterations (e.g., a second predetermined number of decoding iterations that is less than the second maximum number of decoding iterations). Device 110 may be configured to adapt and change these various parameters over time.
In an alternative example, device 110 operates to generate statistics based on different sets of such parameters. Device 110 generates decoding statistics based on both decoding processing operations that use the first maximum of N1=16 decoding iterations and the first predetermined number N2=8 of decoding iterations as well as the second maximum of N1=10 decoding iterations and the second predetermined number N2=5 of decoding iterations when processing the same signals. Concurrent/parallel or serial processing operations may be performed to generate such decoding statistics. Decoding statistics generated based on different parameters may be more desirable in different applications.
With respect to this approach to determine SNR margin and considering a specific example that uses low density parity check (LDPC) coding, note that different LDPC decoders will report different number of average iterations based on the type of decoding approach being employed (e.g., layer decoding vs. flooding decoding vs. other decoding approaches to decode LDPC coded signals). Also, different devices may use different maximum number of iterations for LDPC decoding (e.g., a given chipset or communication device may be implemented to perform only a given maximum number of iterations for LDPC decoding, while another chipset or communication device may use another maximum number of iterations for LDPC decoding), thus the average number of iterations may also vary. Also, note that the average number of iterations may level off at higher SNR.
In one embodiment, chipsets or communication devices may be implemented to map their average number of iterations to the standardized curve of the average number of iterations (e.g., such as using floating-point flooding decoding with 15 maximum number of iterations as shown in
In an example, consider that the device 110 determines an average of approximately 5 decoding iterations is performed when decoding the particular number of signals, e.g. 1000 signals. The device 110 then determines an SNR of 32 dB based on the standardized average iterations curve, and consider a lowest possible SNR of 30 dB, then the SNR margin would be to 2 dB.
In an example, consider that the device 110 determines a DCBR of 1×10−4, then based on a characterization of the device 110, the device 110 determines an SNR of approximately 34.3 dB. Considering a targeted operating SNR of 30 dB, then the device 110 determines an SNR margin of approximately 4.3 dB.
Consider an example using LDPC coding and determining an LDPC-corrected-bit rate (LCBR). As can be seen the diagram, note that the LDPC-corrected-bit rate (LCBR) has better slope at higher SNR than the average number of iterations in the method described above with respect to
Note that some instances may have one LCBR on the whole codeword and/or multiple codewords and/or multiple LCBR's for multiple groups of bits in a codeword. This allows the system to know the SNR margin in different subcarriers and perform bit loading at the tone or subcarrier level (e.g., such as based on orthogonal frequency division multiplexing (OFDM)).
Note also that the LDPC-corrected-bit rate is identical to the channel BER (pre-LDPC-decoding BER) when LDPC decodes successfully. Therefore, this LCBR method does not have any potential issue with different LDPC decoders (e.g., layer decoding or flooding decoding).
Note that a device may be implemented to use any number of different types of FEC code and/or ECC and to generate decoding statistics based thereon. For the assistance of the reader, one type of code, LDPC code, is described in further detail below. However, note that any other desired type of FEC code and/or ECC and decoding statistics associated therewith may be used to determine SNR margin.
LDPC codes are linear block codes and hence the set of all codewords xεC spans the null space of a parity check matrix, H, as follows:
Hx
T=0, ∀xεC (1)
For an LDPC code, the matrix, H, is a sparse binary matrix of dimension m×n. Each row of H corresponds to a parity check and a set element hij indicates that data symbol j used for the parity check i. Each column of H corresponds to a codeword symbol.
For each codeword x, there are n symbols of which m are parity symbols. Hence the code rate of the LDPC code, r, is provided as follows:
r=(n−m)/n (2)
The row and column weights are defined as the number of set elements in a given row or column of H, respectively. The set elements of H are chosen to satisfy the performance requirements of the code. The number of 1's in the i-th column of the parity check matrix, H, may be denoted as dv(i), and the number of 1's in the j-th row of the parity check matrix may be denoted as dc(j). If dv(i)=dv for all i, and dc(j)=dc for all j, then the LDPC code is called a (dv,dc) regular LDPC code, otherwise the LDPC code is called an irregular LDPC code.
A regular LDPC code can be represented as a bipartite graph by its parity check matrix with left side nodes representing variables of the coded bits (or alternatively as the “variable nodes” (or “bit nodes”) 561 in a bit-based decoding of LDPC coded signals), and the right side nodes representing check equations (or alternatively as the “check nodes” 562). The bipartite graph (or Tanner graph) of the LDPC code defined by H may be defined by N variable nodes (e.g., N bit nodes) and M check nodes. Every variable node of the N variable nodes 561 has exactly dv(i) edges. As an example, edge 567 connects the bit node, vi 565, to one or more of the check nodes (within the M check nodes). The edge 567 is specifically shown as connecting from the bit node, vi 565, to the check node, cj 566. This number of dv edges (shown as 563) may be referred to as the degree of a variable node i. Analogously, a check node of the M check nodes 562 has dc(j) edges (shown as dc 564) connecting this node to one or more of the variable nodes (or bit nodes) 561. This number of edges, dc 564, may be referred to as the degree of the check node j.
An edge 567 between a variable node vi (or bit node b) 565 and check node cj 566 can be defined by e=(i,j). Alternatively, given an edge e=(i, j), the nodes of the edge may alternatively be denoted as by e=(v(e),c(e)) (or e=(b(e),c(e))). The edges in the graph correspond to the set elements of H where a set element hji indicates that an edge connects a bit (e.g., variable) node i with parity check node j.
Given a variable node vi (or bit node bi), one may define the set of edges emitting from the node vi (or bit node bi) by Ev(i)={e|v(e)=i} (or by Eb (i)={e|b(e)=i}); these edges are referred to as bit edges, and the messages corresponding to these bit edges are referred to as bit edge messages.
Given a check node cj, one may define the set of edges emitting from the node cj by Ec(j)={e|c(e)=j}; these edges are referred to as check edges, and the messages corresponding to these check edges are referred to as check edge messages. Continuing on, the derivative result will be |Ev(i)|=dv (or |Eb(i)|=db) and |Ec(j)|=dc.
Generally speaking, any such codes (e.g., LDPC codes) that can be represented by a bipartite graph may be characterized as a graph code. It is also noted that an irregular LDPC code may also be described using a bipartite graph. However, the degree of each set of nodes within an irregular LDPC code may be chosen according to some distribution. Therefore, for two different variable nodes, vi
Note that terminology such as that of “bit node” and “bit edge message”, or equivalents thereof, may be used in the art of LDPC decoding. With respect to LDPC decoding, note that “bit node” and “bit edge message” are alternatively referred to as “variable node” and “variable edge message”, respectively. Note that LDPC decoding operates to make one or more estimates of the bit values (or variable values) encoded within an LDPC coded signal.
In an example of LDPC decoding, during initialization, the LLRs are employed for the bit edge messages (e.g., extrinsic information) of the edges extending from the respective bit/variable nodes. Thereafter, one or more decoding cycles or iterations may be performed based on check node processing and bit node processing (iterative decoding 572). Check node processing or check node updating is performed using the original bit edge messages (e.g., the calculated LLRs) such as by a check node processor 574. A bit/variable node processor 573 then uses these updated check edge messages to perform bit node processing or bit node updating to update the variable node soft information for use in the next decoding iteration. The most recently updated variable bit/node soft information is then used to calculate the variable node edge messages (extrinsic information) for this next decoding iteration. The check node processor 574 performs check message updating (based on rows of the LDPC matrix) to generate updated check edge messages, and the bit/variable node processor 573 performs bit or variable edge message updating (based on columns of the LDPC matrix) as also described with reference to
When more than one decoding iteration is performed, these variable node edge messages are then used by the check node processor 574 for subsequent check node processing or check node updating to calculate updated check edge messages. Then, bit/variable node processor 573 uses the most recently updated check edge messages to perform bit node processing or bit node updating to update the variable node soft information once again. After a final decoding iteration, which may be determined based on some parameter (e.g., a predetermined number of decoding iterations or when all syndromes of the LDPC code equal zero, as determined by syndrome calculator 576), the last calculated variable node soft information may undergo hard limiting (e.g., in a slicer or hard limiter 575) to generate one or more estimates of one or more bits encoded within the LDPC coded signal.
Generally speaking, this approach for decoding of LDPC coded signals may be referred to as a message passing approach (or iterative message passing approach). Note that LDPC decoding may be performed in any of a variety of architectures including parallel decoding architectures, layer decoding architectures, etc. Device 110 may be implemented to perform encoding and/or decoding of LDPC coded signal using any desired approach or architecture.
Note that the various functional blocks and components depicted in
In another example of operation, the processor 230 operates to modify a first LDPC matrix to generate a second LDPC matrix for use to decode an LDPC coded signal that is generated based on puncturing of one or more parity bits from another LDPC coded signal.
A processor of a communication device (e.g., processor 230 of communication device 110) may be configured to encode at least one information bit to generate the plurality of LDPC coded bits and/or an LDPC codeword. The processor then transmits the plurality of LDPC coded bits and/or the LDPC codeword, within an LDPC coded signal via a communication interface (e.g., communication interface 320 of communication device 110). The processor may be configured to generate the LDPC coded signal by appropriate modulation of the plurality of LDPC coded bits and/or the LDPC codeword (e.g., processing within an analog front end including digital to analog conversion, filtering, frequency conversion (up or down), gain adjustment, etc.).
A binary LDPC code may be fully described by its parity check matrix (i.e., its LDPC matrix). At the top of the diagram, the individual elements of an LDPC matrix, H, are shown:
where n is the number of bits in a codeword, m is the number of parity check equations of the LDPC code, and hi,j is either 0 or 1. An n-bit vector c (e.g., c=(c1, c2, . . . , cN)) is a codeword (i.e., of the LDPC code) if and only if HcT=0.
For such an LDPC code, the parity matrix H is also composed of a number of q-by-q (i.e., q×q) square sub-matrices as shown in the bottom portion of the diagram and also below:
where M=m/q, N=n/q, and each sub-matrix, SI,J, thereof is a q-by-q sub-matrix that is either an all-zero-valued sub-matrix (i.e., in which all elements thereof are the value of zero “0”, which is depicted by a blank or an empty sub-matrix or a sub-matrix with value of “−1” therein in the associated diagrams) or a CSI (Cyclic Shifted Identity) sub-matrix. A CSI sub-matrix S is characterized by a shift-value, λ(S), (e.g., a right shift value) such that the components of S are defined as follows:
for any i and j, with 0≦i<q and 0≦j<q. For example, the q-by-q identity matrix is itself a CSI matrix with a shift-value λ(S)=0 (i.e., a CSI sub-matrix with a cyclic shift of zero “0”).
As can be seen, the LDPC matrix (as depicted in the lower portion of the diagram), includes various sub-matrix rows and sub-matrix columns. These sub-matrix rows and columns are based on the sub-matrix construction of the LDPC matrix (e.g., shown as sub-matrix rows 0 through M−1 and sub-matrix columns 0 through N−1). This disclosure presents various new designs of LDPC codes.
Note also the following with respect to such LDPC code matrix constructions. A given LDPC code may be a QC (quasi-cyclic)-LDPC code. The definition of such an (n, k) QC-LDPC code is provided as follows:
1. (n-k)-by-n parity check matrix H
2. H is expanded from a binary base matrix Hb of size v-by-u
3. The base matrix Hb is expanded by replacing each sub-matrix in the base matrix with a size z permutation matrix, and each a blank or “−1” negative with a size z zero matrix. The permutations used are circular right shifts as described above, and the set of permutation sub-matrices contains the size z identity matrix and circular right shifted versions of the identity matrix (i.e., CSI sub-matrices).
Because each permutation matrix is specified by a single circular right shift, the binary base matrix information and permutation replacement information can be combined into a single compact model matrix Hbm. The model matrix Hbm is the same size as the binary base matrix Hb, with each binary entry (i,j) of the base matrix Hb replaced to create the model matrix Hbm. Each 0 in Hb is replaced by a blank or “−1” negative to denote a size z all-zero matrix, and each other sub-matrix in Hb is replaced by a circular shift size p(i,j)≧0 (e.g., an entry of “−1” indicates an all-zero-valued sub-matrix, and any other entry such as 0, 1, 2, etc. indicates an identity sub-matrix (if entry is 0), a CSI sub-matrix based on a shift-value of 1 (if entry is 1), a CSI sub-matrix based on a shift-value of 2 (if entry is 2), etc. and so on for any desired cyclic shift-value). The model matrix Hbm can then be directly expanded to the entire LDPC matrix, H.
Note also that such CSI sub-matrices may be based on different CSI values. A CSI value of zero indicates an identity sub-matrix. A CSI value of 1 indicates an identity sub-matrix that has undergone a cyclic shift by 1. Any desired CSI value may be employed up to the sub-matrix size, z, if considering sub-matrices of size z-by-z. Generally speaking, a CSI value of x indicates an identity sub-matrix that has undergone a cyclic shift by x.
While examples have been provided showing LDPC decoding, processor 230 can also be configured to perform encoding of bit(s) to generate LDPC coded bit(s) and/or LDPC codeword(s). Such encoding may be performed using back-substitution. An LDPC matrix may be partitioned into a left hand side matrix, HLHS, and a right hand side matrix, HRHS, such as shown in
Considering a right hand side matrix, HRHS, having the form of those in
The processor 230 then encodes the input (information) bits and computes L·m parity bits, cpar (e.g., LDPC coded bits) as follows: cpar=(ck, ck+1, . . . , cLn−1)
The processor 230 then outputs the following:
For a right hand side matrix, HRHS, in the form of those in
The encoding procedure may be described as follows:
Input: c1=(c0, c1, . . . , ck−1)
Step 1: compute Vi=HI,icIT, such that i=0, . . . , 4.
Step 2: back-substitution
C
0
=V
0(L−u0,0)
C
1
=V
1(L−u1,1)+C0((L−u1,1+u1,0)mOd L)
C
2
=V
2(L−u2,2)+C1((L−u2,2+u2,1)mOd L)
C
3
=V
3(L−u3,3)+C2((L−u3,3+u3,2)mOd L)
C
4
=V
4(L−u4,4)+C3((L−u4,4+u4,3)mOd L)
Note that this approach shows just one possible example by which encoding based on an LDPC code may be performed. Generally, the decoding operations described herein may be performed on an LDPC coded signal that is generated using any LDPC encoding approach.
In this diagram, LDPC decoder 710 receives coded signals or data and performs iterative decoding thereon to make estimates of information encoded therein. The operations within the block 722 generate an LDPC syndrome failure total. These operations determine an LDPC syndrome failure total at a predetermined number of iterations, N, that is fewer than a maximum number of LDPC decoder iterations performed by LDPC decoder 710. For example, the error check failure status is determined at the predetermined number of iterations, N, when decoding each of the signals. After decoding a certain number of signals, the device determines the LDPC syndrome failure total based on LDPC syndrome failure status of at least one of the plurality of LDPC coded signals after performing the predetermined number of decoding iterations, N. The LDPC syndrome failure rate is the ratio of the LDPC syndrome failure total to the total number of LDPC codewords decoded (e.g., the LDPC syndrome failure total divided by the total number of LDPC codewords decoded). The device applies the LDPC syndrome failure total to a number of the LDPC coded signals to a characterization of the communication device that relates error check rate and SNR.
From another perspective, the LDPC decoder 710 iteratively decodes LDPC coded signals to make estimates of information encoded therein. The block 722 determines a syndrome failure total based on syndrome failure of at least one of the plurality of LDPC coded signal after performing a predetermined number of iterations, N, that can be fewer than a maximum number of LDPC decoder iterations performed by LDPC decoder 710. The device then applies the syndrome failure total relative to the number of LDPC coded signals decoded to generate the operational error check rate. For example, the device divides the syndrome failure total by the number of LDPC coded signals decoded to generate the operational error check rate. The device then determines the SNR margin of the communication device by applying the operational error check rate to a characterization of the communication device that relates syndrome error rate and SNR.
This implementation of
With respect to modulation 820, information may be modulated to generate discrete-valued modulation symbols using various modulation coding techniques. Examples of such modulation coding techniques may include binary phase shift keying (BPSK), quadrature phase shift keying (QPSK) or quadrature amplitude modulation (QAM), 8-phase shift keying (PSK), 16 quadrature amplitude modulation (QAM), 32 amplitude and phase shift keying (APSK), 64-QAM, etc., uncoded modulation, and/or any other desired types of modulation including higher ordered modulations that may include even greater number of constellation points (e.g., 1024 QAM, etc.). Generally, data within a packet may be modulated using a relatively higher-ordered modulation/modulation coding sets (MCSs) than is used for modulating SIG information. Relatively lower-ordered modulation/MCS may be used for the SIG information to ensure reception by a recipient device (e.g., being relatively more robust, easier to demodulate, decode, etc.). In an example of operation, when there is an adequate SNR margin, a transmitting device may increase the modulation density used to transmit subsequent signals (e.g., adjust from 16 QAM up to 64 QAM).
With respect to transmit power 830, a device may be implemented to transmit signals using any one of a number of different transmit powers. SNR margin of communications between two devices is determined to be relatively large, a transmitting device may adjust down transmit power to a relatively lower power to operate with a relatively smaller SNR margin. Generally speaking, the value of any operational parameter may be adjusted based on information related to SNR margin.
The method 901 then operates by determining an operational error check rate based on error check failure of at least one of the plurality of FEC coded signals after performing a number of decoding iterations, N (block 930). The operational error check rate is a measure of an error check failure total relative to the number of FEC coded signals that have been decoded (e.g., the error check failure total divided by the number of FEC coded signals that have been decoded). Note that the number of decoding iterations, N, may be predetermined, configurable, etc. note that this number of decoding iterations is less than the maximum number of decoding iterations to be performed within the method 901. The method 901 continues by determining a signal to noise ratio (SNR) margin of the communication device by applying the operational error check rate to a characterization of the communication device that relates error check rate and SNR (block 940).
The method 902 continues by transmitting, via the communication interface, the SNR margin to the other communication device for use in adjusting operation of the other communication device (block 931). The method 902 continues by receiving, via the communication interface, at least one additional FEC coded signal based on a second power that is different than the first power from the other communication device (block 941).
As may be used herein, the terms “substantially” and “approximately” provides an industry-accepted tolerance for its corresponding term and/or relativity between items. Such an industry-accepted tolerance ranges from less than one percent to fifty percent and corresponds to, but is not limited to, component values, integrated circuit process variations, temperature variations, rise and fall times, and/or thermal noise. Such relativity between items ranges from a difference of a few percent to magnitude differences. As may also be used herein, the term(s) “configured to,” “operably coupled to,” “coupled to,” and/or “coupling” includes direct coupling between items and/or indirect coupling between items via an intervening item (e.g., an item includes, but is not limited to, a component, an element, a circuit, and/or a module) where, for an example of indirect coupling, the intervening item does not modify the information of a signal but may adjust its current level, voltage level, and/or power level. As may further be used herein, inferred coupling (i.e., where one element is coupled to another element by inference) includes direct and indirect coupling between two items in the same manner as “coupled to”. As may even further be used herein, the term “configured to,” “operable to,” “coupled to,” or “operably coupled to” indicates that an item includes one or more of power connections, input(s), output(s), etc., to perform, when activated, one or more its corresponding functions and may further include inferred coupling to one or more other items. As may still further be used herein, the term “associated with,” includes direct and/or indirect coupling of separate items and/or one item being embedded within another item.
As may be used herein, the term “compares favorably” or equivalent, indicates that a comparison between two or more items, signals, etc., provides a desired relationship. For example, when the desired relationship is that signal 1 has a greater magnitude than signal 2, a favorable comparison may be achieved when the magnitude of signal 1 is greater than that of signal 2 or when the magnitude of signal 2 is less than that of signal 1.
As may also be used herein, the terms “processing module,” “processing circuit,” “processor,” and/or “processing unit” may be a single processing device or a plurality of processing devices. Such a processing device may be a microprocessor, micro-controller, digital signal processor, microcomputer, central processing unit, field programmable gate array, programmable logic device, state machine, logic circuitry, analog circuitry, digital circuitry, and/or any device that manipulates signals (analog and/or digital) based on hard coding of the circuitry and/or operational instructions. The processing module, module, processing circuit, and/or processing unit may be, or further include, memory and/or an integrated memory element, which may be a single memory device, a plurality of memory devices, and/or embedded circuitry of another processing module, module, processing circuit, and/or processing unit. Such a memory device may be a read-only memory, random access memory, volatile memory, non-volatile memory, static memory, dynamic memory, flash memory, cache memory, and/or any device that stores digital information. Note that if the processing module, module, processing circuit, and/or processing unit includes more than one processing device, the processing devices may be centrally located (e.g., directly coupled together via a wired and/or wireless bus structure) or may be distributedly located (e.g., cloud computing via indirect coupling via a local area network and/or a wide area network). Further note that if the processing module, module, processing circuit, and/or processing unit implements one or more of its functions via a state machine, analog circuitry, digital circuitry, and/or logic circuitry, the memory and/or memory element storing the corresponding operational instructions may be embedded within, or external to, the circuitry comprising the state machine, analog circuitry, digital circuitry, and/or logic circuitry. Still further note that, the memory element may store, and the processing module, module, processing circuit, and/or processing unit executes, hard coded and/or operational instructions corresponding to at least some of the steps and/or functions illustrated in one or more of the Figures. Such a memory device or memory element can be included in an article of manufacture.
One or more embodiments of an invention have been described above with the aid of method steps illustrating the performance of specified functions and relationships thereof. The boundaries and sequence of these functional building blocks and method steps have been arbitrarily defined herein for convenience of description. Alternate boundaries and sequences can be defined so long as the specified functions and relationships are appropriately performed. Any such alternate boundaries or sequences are thus within the scope and spirit of the claims. Further, the boundaries of these functional building blocks have been arbitrarily defined for convenience of description. Alternate boundaries could be defined as long as the certain significant functions are appropriately performed. Similarly, flow diagram blocks may also have been arbitrarily defined herein to illustrate certain significant functionality. To the extent used, the flow diagram block boundaries and sequence could have been defined otherwise and still perform the certain significant functionality. Such alternate definitions of both functional building blocks and flow diagram blocks and sequences are thus within the scope and spirit of the claimed invention. One of average skill in the art will also recognize that the functional building blocks, and other illustrative blocks, modules and components herein, can be implemented as illustrated or by discrete components, application specific integrated circuits, processors executing appropriate software and the like or any combination thereof.
The one or more embodiments are used herein to illustrate one or more aspects, one or more features, one or more concepts, and/or one or more examples of the invention. A physical embodiment of an apparatus, an article of manufacture, a machine, and/or of a process may include one or more of the aspects, features, concepts, examples, etc. described with reference to one or more of the embodiments discussed herein. Further, from figure to figure, the embodiments may incorporate the same or similarly named functions, steps, modules, etc. that may use the same or different reference numbers and, as such, the functions, steps, modules, etc. may be the same or similar functions, steps, modules, etc. or different ones.
Unless specifically stated to the contra, signals to, from, and/or between elements in a figure of any of the figures presented herein may be analog or digital, continuous time or discrete time, and single-ended or differential. For instance, if a signal path is shown as a single-ended path, it also represents a differential signal path. Similarly, if a signal path is shown as a differential path, it also represents a single-ended signal path. While one or more particular architectures are described herein, other architectures can likewise be implemented that use one or more data buses not expressly shown, direct connectivity between elements, and/or indirect coupling between other elements as recognized by one of average skill in the art.
The term “module” is used in the description of one or more of the embodiments. A module includes a processing module, a processor, a functional block, hardware, and/or memory that stores operational instructions for performing one or more functions as may be described herein. Note that, if the module is implemented via hardware, the hardware may operate independently and/or in conjunction with software and/or firmware. As also used herein, a module may contain one or more sub-modules, each of which may be one or more modules.
While particular combinations of various functions and features of the one or more embodiments have been expressly described herein, other combinations of these features and functions are likewise possible. The present disclosure of an invention is not limited by the particular examples disclosed herein and expressly incorporates these other combinations.
The present U.S. Utility patent application claims priority pursuant to 35 U.S.C. §119(e) to U.S. Prov. Patent App. No. 61/884,116, entitled “Signal to noise ratio (SNR) margin determination based on low density parity check (LDPC) decoding statistics,” filed Aug. 29, 2013, which is hereby incorporated herein by reference in its entirety and made part of the present U.S. Utility patent application for all purposes.
Number | Date | Country | |
---|---|---|---|
61884116 | Sep 2013 | US |