The invention relates to communications systems generally and more particularly relates to multicasting multimedia streaming systems.
Multimedia streaming over heterogeneous digital networks is one of the fastest growing applications both in terms of traffic demands and in terms of market potential. Systems can include a server, multicasting a multi-media source (audio/video) to a number of clients. Such systems lack a mechanism to provide real-time multicasting where the decoding delay is the same for all users; but each user reconstructs the source at a possibly different distortion, level, depending on its own channel capacity.
A source channel encoder, source channel decoder and methods for implementing such devices are disclosed herein. The source channel encoder includes a linear transform encoder configured to generate a plurality of source components. A successive refinement quantizer is configured to generate a plurality of bit planes based on the source components. A systematic linear encoder is configured to map the bit planes into channel-encoded symbols. The linear transform encoder may be configured to apply a Discrete Cosine Transform (DCT) or a Discrete Wavelet Transform (DWT). The linear transform encoder may be configured for differential encoding. The quantizer may be configured to generate a top (most significant) bit plane and a plurality of lower significance bit planes configured with decreasing resolution. The systematic linear encoder may include a Raptor encoder. The systematic linear encoder may be configured to directly map the bits planes into the channel-encoded symbols, e.g., without an intervening compression function. The systematic linear encoder may be configured to generate a minimum number of channel coded symbols based on a pre-determined distortion level. The systematic linear encoder may be configured to minimize a weighted sum of distortion levels based on a pre-determined number of channel coded symbols. The systematic linear encoder may be configured to minimize a maximum gap with respect to individual optimal distortion across all users based on a pre-determined number of channel coded symbols.
The source channel decoder includes a plurality of Belief Propagation (BP) decoders configured for successive decoding. Each BP decoder is associated with a single bit plane and is configured to generate a soft estimate of the bit plane based on an a-posteriori Log-Likelihood Ratio (LLR). A reconstruction engine is configured to produce an estimate of a source sample based on the a-posteriori LRRs generated by the BP decoders. The BP decoders may be configured to generate a hard estimate based on a Maximum A-posteriori Probability (MAP). The hard estimate may be passed to a successive BP decoder stage. The reconstruction engine may be configured to produce an estimate of the source sample based on minimum mean-square error (MMSE) criterion.
The method of encoding a source includes transforming the source using a linear transform and generating a plurality of source components. Successive refinement quantization is performed and a plurality of bit planes are generated based on the source components. Systematic linear encoding is performed to map the bit planes into channel-encoded symbols. The linear transform may be a Discrete Cosine Transform (DCT) or a Discrete Wavelet Transform (DWT). The linear transform may generate differential encoding. Top (most significant) bit plane and a plurality of lower significance bit planes configured with decreasing resolution may be generated. Raptor encoding may be performed. The bits planes may be directly mapped into the channel-encoded symbols. A minimum number of channel coded symbols may be generated based on a pre-determined distortion level. A weighted sum of distortion levels may be minimized based on a pre-determined number of channel coded symbols. A maximum gap may be minimized with respect to individual optimal distortion across all users based on a pre-determined number of channel coded symbols.
The decoding method includes successively decoding a plurality of bit planes and generating a soft estimate of each bit plane based on an a-posteriori Log-Likelihood Ratio (LLR). An estimate of a source sample is generated based on the a-posteriori LRRs. A hard estimate may be generated based on a Maximum A-posteriori Probability (MAP). The hard estimate may be passed to a successive decoder stage. An estimate of the source sample may be generated based on minimum mean-square error (MMSE) criterion.
a is a block of an encoder;
b is a block diagram showing encoder functionality;
Multimedia streaming over heterogeneous digital networks is one of the fastest growing applications both in terms of traffic demands and in terms of market potential. Systems can include a server, multicasting a multi-media source (audio/video) to a number of clients. In one embodiment, a system can include support at the application layer. The underlying network (from the server to the clients) can be modeled as an erasure broadcast channel. Erasures represent packets that are lost in the network, for any reason such packet dropped due to congested nodes, or packet dropped because corrupted by unrecoverable channel errors. The underlying network may encompass any sort of heterogeneous wired or wireless network without departing from the scope of this disclosure. For example, the system may be formed using an Internet backbone, connected to a wireless router, or to a wireless cellular base station, or even with a DSL line to the end users.
A multimedia streaming application is generally an overlay system, that is, it operates at the application layer by using a fixed transport mechanism already built-in to the network, e.g., the User Datagram Protocol (UDP) currently used as an alternative to TCP on top of the ubiquitous Internet Protocol (IP). A conventional approach consists of establishing individual streaming sessions from the server to each user. This may be very inefficient when many users wish to receive the same content (e.g., in mobile television or video on demand applications). As disclosed herein, it is possible to use an efficient scalable Joint Source-Channel Coding (JSCC) for the transmission of a source over an Erasure Broadcast Channel. This approach is referred to as JSCC at the application layer since the underlying physical channels is disregarded, in contrast to most common JSCC approaches.
A system may be formed as follows: at the encoder (server), a natural multimedia source is encoded using standard transform coding, with possible differential encoding in order to reduce the redundancy in the time domain. The subbands of the transform/differential encoder are quantized by multiresolution (embedded) quantization, thus producing redundant bit-streams for successive refinement. Instead of using conventional entropy coding (e.g., arithmetic coding) in order to remove the redundancy in the bit-streams, the redundant bits are directly mapped onto channel-encoded symbols, using a family of linear encoders. The linear encoding of the bit-streams is performed independently, for each bit-stream, and may be implemented by any good family of systematic linear codes with tunable rate (for example, this can be obtained using a rateless code, a library of punctured turbo codes, a library of LDPC codes etc. . . . ). The allocation of the source layers to different users is optimized according to an optimal resource allocation algorithm that can incorporate suitable distortion criteria. At each decoder (client), the source layers are decoded successively, up to the layer allocated to the given user. Decoding may be performed using low-complexity Belief Propagation iterative decoding. The source may be reconstructed according to the minimum mean-square error (MMSE) criterion using softbit reconstruction. The system may be implemented using rateless codes and in particular Raptor Codes, since they offer a simple way to generate a very flexible adaptive rate encoding.
This disclosure encompasses systems used in real-time multicasting where the decoding delay is the same for all users, but each user reconstructs the source at a possibly different distortion level, depending on its own channel capacity. The embodiments disclosed herein can be naturally applied to static broadcasting (e.g., video on demand applications), if used jointly with well-known protocols such as harmonic broadcasting. Simulation results may be used to assess the effectiveness the proposed coding scheme showing that it can achieve end-to-end distortion performance very close to the theoretical limits with finite block length and low encoding/decoding complexity.
Encoding
A system may be formed with the following building blocks: an encoder (at the server), and decoders (at the clients). A description of the encoding and decoding processes is set forth below. For the sake of simplicity, the specific example of sending a digital picture is used. The disclosed techniques may be directly applied to video, with frame-by-frame encoding. As detailed below, the same encoding principle can be combined with standard differential encoding for video, in order to encode the residual frames after the elimination of the time-redundancy by motion compensation (as in the MPEG-2, MPEG-4 and H.264 standards). Also, the disclosed techniques may be combined with so-called harmonic broadcasting (also known as skyscraper architecture), in order to implement video on demand applications with low waiting time.
a is a block diagram of a source channel encoder 50 implemented in accordance with this disclosure. The encoder 50 includes a linear transform encoder 52 configured process a source input and generate a plurality of source components. A successive refinement quantizer 54 is configured to generate a plurality of bit planes based on the source components. A systematic linear encoder 46 is configured to map the bit planes into channel-encoded symbols for output. The encoder may also include one or more processors 58. The encoder 50 can be implemented in hardware, software or a combination of both as is well known in the art with respect to such devices. It should also be understood that encoder 50 may be embedded within other devices such as a server.
1) Transform encoding, e.g., differential encoding in the case of video, followed by a linear transform of the resulting frames, e.g., Discrete Cosine Transform (DCT), Discrete Wavelet Transform (DWT). This example is directed to the encoding of a single image (single frame) and use of a DWT generally in accordance with the JPEG-2000 image compression standard. It should be understood that the techniques disclosed herein may be used with any suitable linear transform. In this example, S is an s×k array of transform coefficients. Each row of S, denoted by S(i), is referred to as a source component (encoded separately).
2) Quantization—each source component S(i) is quantized by using a family of embedded nonuniform scalar quantizers. In this example, the quantization function is denoted as Q:→{0,1}P, where 2P is the number of quantization regions for the highest level of refinement. DQ(p) denotes the distortion for the unit-variance source, with 0≦p≦P quantization bits, it follows that the distortion for the i-th source component is given by DQ,i(p)=σi2DQ(p), where σi2 denotes the variance of S(i). The quantizer output for source S(i) is a binary array U(i) of dimension P×k, such that each column uj(i) contains the binary representation of the quantization of the corresponding source symbol sj(i). The rows of U(i), denoted by U(o,:)(i) for p=1, . . . , P, are referred to as bit-planes. Given the multiresolution embedded nature of the quantizer, the source is going to be reconstructed with distortion σi2DQ(p), provided that the top (most significant) p bit-planes are used by the decoder, while disregarding completely the bottom (least significant) P-p bit-planes. The number of bit-planes that must be used for reconstruction by decoders in each user class l is indicated by πi,l. The determination of the values πi,l for all source components i and user class l defines a bit-allocation. The determination of the optimal bit-allocation for a given source frame S and users' capacities C1≦ . . . ≦CL depends on the desired objective function to be optimized. This forms the so-called resource allocation problem, is discussed below.
3) Linear encoding of the bit-planes into channel symbols—
for p=1, . . . , P and i=1, . . . , s, where it is understood that if some bit-plane is encoded with zero bits, the corresponding codeword is not present. The total source-channel encoder output length is given by:
where, by definition, πi,0=0. Due to the degraded nature of the Erasure Broadcast Channel, the user l is able to decode all blocks (p,i) for 1≦p≦πi,l and i=1, . . . , s. The bit-planes can be decoded in sequence, using the multi-stage decoder described below. The overall number of channel encoded binary symbols per source symbol is given by n/(sk).
Decoding
The following disclosure focuses on the decoder of user class l. For each source component, the decoder wishes to reconstruct an approximation, in the MMSE sense, of the source block S(i). In order to do so, it decodes the bit-planes 1, 2, . . . , πi,l for all i=1, . . . , s. The bit-planes of each source component can be decoded separately from the other source components. We focus on the decoder for the i-th source component. The same technique may be applied to all source components i=1, . . . , s and for all user classes l=1, . . . , L.
The input lines 22, 24 and 26 indicate the flow of the received signal (from the l-th channel output), lines 28, 30 and 32 indicate the flow of the hard decisions, propagated through the successive decoding stages, and lines 34, 36, 38 and 40 indicate the flow of the decoders soft-output and reconstructed estimated source block. As discussed above, the decoder 20 may also include one or more processors 10. The decoder 20 can be implemented in hardware, software or a combination of both as is well known in the art with respect to such devices. It should also be understood that decoder 20 may be embedded within other devices such as a client device, e.g., a computing device, network appliance, mobile phone, television or other multimedia device. The decoder functionality is carried out by the following building blocks:
Successive Decoding: In order to decode the (p, i)-th bit-plane, the decoder must make use of the conditional a-priori probability (U(p,:)(i)|(U(1,:)(i), . . . , U(p-1,:)(i)) of the p-th bit-plane, conditioned on the previous bit-planes 1, . . . , p−1. The conditional probability mass function (U(p,:)(i)|U(1,:)(i), . . . , U(p-1,:)(i)) is encoded and sent as a header information directly to the decoders, and therefore it is known to the decoders.
The bit-planes may be decoded in sequence (successive decoding). Bit-plane (U(1,:)(i) may be decoded first, using the a-priori probability mass function (U(1,:)(i)), known from the header information. This is decoder stage 1. Then, bit-plane (U(2,:)(i) may be decoded using the probability mass function (U(2,:)(i)|Û(1,:)(i)), where Û(2,:)(i) denotes the decoded bit-plane decision made at stage 1. In decoder stage 2, bit-plane (U(3,:)(i) be decoded using the probability mass function (U(3,:)(i)|Û(1,:)(i), Û(2,:)(i)), where Û(2,:)(i) the decoded bit-plane decision made at stage 2. In decoder stage 3, the successive decoding process continues until the required bit-plane index πi,l.
Iterative Message Passing Decoding with soft-output, for each stage: Let Y(p,:),l(i) denote the channel output received by user l corresponding to the transmission of X(p,:)(i). The optimal decoding rule at each stage p of the multi-stage successive decoder operates according to the Maximum A-posteriori Probability (MAP) principle, according to the rule
For sparse-graph codes, the MAP rule above would be computationally too complex. Instead, a low complexity iterative Belief Propagation algorithm (BP) may be used at each stage of the multi-stage decoder. Raptor Codes may be used for the linear encoding of the bit-planes. The BP decoder, at each stage p, produces a sequence of Extrinsic Log-Likelihood Ratios (Ext-LLRs) (see Appendix A) denoted by {ξ(p,j),l(i): j=1, . . . , k}. The Ext-LLRs are combined with the source a-priori LLRs, given by λp,j(i)(u1, . . . , up-1), as defined in Appendix B, in order to obtain the a-posteriori LLRs, given by Λ(p,j),l(i)(u1, . . . , up-1)=ξ(p,j),l(i)+λp,j(i)(ul, . . . , up-1). Then, for each quantization bit (p, j) a hard-decision is made according to the MAP symbol-by-symbol rule:
These hard decisions are passed to the next stage p+1.
Soft-bit MMSE reconstruction: the collection of all a-posteriori LLRs {(p,j),l(i)} for all p, j and i are used for the source reconstruction according to the minimum MSE (MMSE) criterion, according to the rule (see Appendix B):
where c(i)(u1, . . . , uπ
Resource Allocation
The Binary Erasure Broadcast Channel (BEBC) with L receiver classes has input alphabet {0,1}, output alphabet {0,1,e} (“e” denoting erasure), and is defined by L Binary-Erasure Channels (BECs) with erasure probability ε1≦ . . . ≦εL and capacity Cl=1−εL. For simplicity, each class is referred to as a “user” since, in a multicast scenario, all users belonging to the same class are statistically equivalent and achieve the same performance. The capacity region of the BEBC is given by:
This region is achieved by time-sharing of the coding strategies that achieve the vertices of the region's dominant face, corresponding to the individual user capacities. A “broadcast code” for the BEBC is obtained by multiplexing (time-sharing) single-user codewords for the different users. The BEBC belongs to the class of stochastically degraded broadcast channels. Whatever can be decoded by user l, can also be decoded by all users j>l.
An (s×k)-to-n source-channel multicast code for the BEBC is formed by an encoding function ƒ: s×k→{0,1}n such that S is mapped into the channel input codeword X=ƒ(S), and by L decoding functions gl: {0,1,e}n→s×k, for l=1, . . . , L, such that at each l-th user receiver, the received channel output Yl is mapped into the reconstructed source block Ŝl=gl(Yl).
The details of the encoding function ƒ(·) and decoding functions gl(·) for the proposed scheme are detailed above. The following disclosure is directed to optimizing system parameters in order to achieve optimal distortion according to certain specific criteria. A Weighted MSE (WMSE) distortion measure may be defined as follows. Let the MSE distortion for the l-th decoder and the i-th source component be given by
Then, the WMSE distortion at the l-th decoder is defined as:
where {υi≧0: i=1, . . . , s}, are weights that depend on the specific application. Let ri(·) denote the R-D function of the i-th source component with respect to the MSE distortion. Then the R-D function of S is given by:
Where {di: i=1, . . . , s} are dummy optimization variables, corresponding to the individual MSE distortions of the i-th source components.
The functions {ri(d): i=1, . . . , s} depend the specific scalar embedded quantizer Q(·) as disclosed above. These functions are convex and non-increasing, and identically zero for
Each source component may be encoded individually, into L successive refinement codewords of appropriate rates. The s codewords at successive refinement level l form the l-th source layer. Layers may be channel-encoded at a rate as close as possible to the capacity Cl, such that all users j≧l can successfully decode, but no user j<−l can. Each user l reconstructs the source using all layers from 1 to l.
Assume that b=n/(ks) is the number of channel-coded bit per source sample (referred to as “pixel” in the following). The ratio b measures how many channel-encoded bits must be sent, on average, for each source pixel, and it is indicated in bit-per-pixel (bpp). Let R′i,l, for i=1, . . . , s and l=1, . . . , L, denote the source coding rate of source component i at successive refinement level l. This corresponds to kR′i,l information bits. Let Rl denote the channel coding rate of layer l. Then, we have
where the channel coding rate L-tuple (R1, . . . , RL) must be in the BEBC capacity region. The distortion for user l is given by:
As disclosed in the Encoding section, sparse-graph codes (in particular, Raptor Codes) may be used to perform the linear encoding of the bit-plane bits into channel codewords. A common feature of these codes is that they exhibit a post-decoding erasure rate characterized by a very sharp “waterfall” behavior: if R<C/(1+θ), for some code-dependent factor θ>0, then the residual erasure probability is extremely small (in fact, it vanishes in the limit of infinite block length). Otherwise, for R>C/(1+θ), the residual erasure probability is ≈ε=1−C, i.e., the code is ineffective to recover the channel erasures. The code operates “below threshold” if R<C/(1+θ). Otherwise, the code operates “above threshold”. Since Raptor codes may be used, θ is referred to as the coding overhead.
This layered approach is defined by the family of successive refinement source codes described by their R-D functions {ri(d): i=1, . . . , s}, and by a family of channel codes characterized by their overhead parameters {θl:l=1, . . . , L}. Three system optimization problems, for three different performance criteria are set forth below:
Minimum Bandwidth (MB): For given user target distortions Δ1≧ . . . ≧ΔL, we wish to minimize the number of coded bpp b. Using the equations disclosed above, we have the following problem:
This problem is immediately solved as follows: letting R(Δ0)=0, we find that a necessary condition for optimality is that the inequyities bRl≧R(Δl)−R(Δl-1) holds with equality for all l=1, . . . , L. Replacing these equalities into the capacity region constraint, we obtain the solution:
Min Weighted Total Distortion (MWTD): For given b and non-negative weights {l}, we wish to minimize Σl=1LlDl. The problem can be formulated as:
where the optimization variables are the partial source-layer distortions {Di,l} and the channel coding rates {Rl}, and where σi2 denotes the variance (per symbol) of the i-th source component S(i).
Min-Max Distortion Penalty (MMDP): For given b, we wish to minimize maxl=1, . . . , LDl/Dlopt, where Dlopt=R−1(bCl) is the R-D bound for user l as if it was the only user in the system (single-user bound) and ideal (capacity achieving) channel coding was possible. The problem can be formulated as:
where the optimization is with respect to a, Di,l and {Rl}. The following sections particularize the above problems to some significant cases.
In order to apply the general optimization problems to this setting, we need to define the R-D functions ri(d). Let U(i)=Q(S(i)) denote the sequence of binary quantization indices, formatted as an P×k binary array. The p-th row of U(i), denoted by U(p,:)(i), is referred to as the p-th “bit-plane”. Without loss of generality, we let U(1,:)(i) denote the sign bit-plane, and U(2,:)(i), . . . , U(p,:)(i) denote the magnitude bit-planes with decreasing order of significance. The quantizer output U(i) can be considered as a discrete memoryless source, with entropy rate
(in bits/source symbol). Using the chain rule of entropy, this can be decomposed as H(i)=Σp=1pHp(i), where the conditional entropy rates of the bit-planes are denoted by:
Then, the set of R-D points achievable by the embedded scalar quantizer using 0, 1, . . . , P quantization bits is given by:
where, by definition, DQ,i(0)=σi2. Using time-sharing, any point in the convex hull of the above achievable points is also achievable. Finally, the operational R-D curve ri(d) of the scalar quantizer is given by the lower convex envelope of the convex hull of the points in the equation above. It is easy to see that since P is finite, then ri(d) is a piecewise linear function. Therefore, the resulting function ri(d) is convex and decreasing on the domain, DQ,i(P)≦d≦σi2.
As seen from
where the coefficients ai,p and bi,p are obtained from the prior equation (details are omitted for the sake of brevity). It is also possible to obtain the operational R-D function of the parallel source as the solution of a linear program. Introducing the auxiliary variables we have:
The MWTD and MMDP problems defined before can be modified to include the case of a given entropycoded embedded quantization scheme, by using the above formulas directly into the optimization problems. For example, the MMDP problem can be written as follows:
This problem formulation applies to any family of successive refinement source codes that can operate at a finite set of possible R-D points.
In general, the coding rate overhead at each bit-plane may be allocated such that each stage of the multi-stage BP decoder works with enough reliability in order to: 1) provide reliable hard decisions (3) in order to avoid error propagation in the multi-stage decoder; 2) achieve output distortion close enough to the designed quantization distortion. For each p-th bit plane of the i-th source component, the overhead θp,i,l can be optimized numerically, for the given family of codes. The values θ(p,i,l) depend, in general, on the bit-plane entropy Hp(i), on the source statistics and on the l-th user channel capacity, as well as on the coding block length k. Fortunately, for the family of Raptor codes used herein, we have observed that the dependence of the factors θp,i,l on the source statistics and on the channel capacity is very weak. In fact, for a given block length k, we can choose a set of values {θp: p=1, . . . , P} that is uniformly good for all sources and channel capacities.
Once the coding overhead factors {θp: p=1, . . . , P} have been found (this can be done off-line and is not part of the encoding algorithm), system optimization may proceed. For a given bit-plane to layers allocation defined by the integers {πi,l} (see
This is the same bandwidth efficiency corresponding to ideal channel coding (zero overhead), and a modified quantizer operational R-D function characterized by the set of R-D points:
It follows that the corresponding system optimization problems are formally identical to what given before, in the case of ideal channel coding, e.g., letting θl=0 in (17), with the piecewise linear R-D functions (15) defined for the modified R-D points.
As an example of the application of the system optimization framework developed above, we consider the case of lossy multicasting of digital (gray-scale) images over the BEBC. Two embodiments are designed according to the MMDP criterion. The former is based on the concatenation of a state-of-the art image coder, JPEG2000, with standard non-systematic Raptor codes. The latter is based on scalar quantization with linear index coding, as presented above.
JPEG2000 and Raptor codes—this case can be cast within the problem formulation set forth above, for a single source component (s=1) and where JPEG2000 plays the role of the successive refinement source code. JPEG2000 produces a bit-stream of source-encoded bits with the property that the encoder output for any given bit rate is a prefix of the output for any higher bit rate. For a given source image we can generate a set of R-D points by considering an increasing number of JPEG2000 output bits, sequentially. We considered the points (rp, dp) on the successive refinement R-D curve generated by applying JPEG2000 to the test image that we wish to encode. In particular, we considered the rate points {rp: p=1, . . . , P} uniformly spaced in the interval [0.001; 1.2]. The lower convex envelope of the straight lines interpolating these points defines the operational R-D function Rjpeg(D) of the source encoder.
For the MMDP problem, since the “true” R-D function of a given test image is not defined, we consider the operational single-user bounds Dlopt=Rjpeg−1(bCl). The solution of the system optimization problem yields a set of user distortions {Dl: l=1, . . . , L}. Correspondingly, the JPEG2000 encoder produces L successive refinement layers of size ml=k (Ripeg(Dl)−Rjpeg(Dl-1)), where Rjpeg(D0=0). Eventually, each l-th layer output by the JPEG2000 encoder is mapped into a channel codeword of length nl=ml(1+θl)/Cl by the Raptor encoder, and the L codewords are transmitted in sequence over the BEBC. The degree sequence and the LDPC precoder for the Raptor code used in this example are set forth in Appendix A. Raptor codes over the binary-erasure channel have an overhead θl that depends on the coding block length but it is independent of the channel erasure probability. For the Raptor code ensemble used here and block lengths of the example, the overhead is θ=0.065.
JPEG2000 produces a header containing very sensitive information, the loss of which prevents from reconstructing the source at any level of refinement. In this example, the header is formed by 255 bytes. The header information was separately encoded using channel coding rate 0.1 (much lower than the worst user capacity C1 for which the technique is optimized), so that the header is decoded by all users with negligible probability of error. The encoded header accounts for less than 5% of the overall bandwidth efficiency.
Quantization with linear index coding—in this case, the source image is decomposed into a set of “parallel” source components by a suitable linear transform. In this example, the DWT of JPEG2000 set forth above was used. Using W levels of DWT, the transformed image is partitioned into 3 W+1 “subbands”.
Similarly to the case of parallel Gaussian sources, each source component block may be independently quantized using a suitably optimized non-uniform embedded scalar quantizer. Then, the quantized bit-planes are linearly encoded using a systematic Raptor encoder (again, the Raptor degree sequence and LDPC precoder for this example are given in Appendix A). The quantizer R-D points are obtained by measuring the actual quantizer distortion on each source component block. In this example, for a test image of size 1024×1024 with DWT depth W=3 we have source component blocks of length k=16384, which coincides with the size of the LL0 subband.
The multi-stage BP decoder needs the knowledge of the conditional bit-plane pmfs for each source component. While for the parallel Gaussian source model these probabilities are known a priori, in the case of digital images this must be estimated from the sequence of quantized DWT coefficients. In conventional source coding schemes (e.g., JPEG2000) these probabilities are implicitly estimated by using sequential probability estimators implemented together with the bit-plane context model and arithmetic coding. With linear index coding, these probabilities may be estimated by ML probability estimators and encoded into a header. The corresponding a-priori LLRs defined above are encoded and suitably quantized by using a number of bits dictated by the Rissanen bound, as discussed above. The bit-plane a-priori probabilities and the source components empirical variances and means form the header information for the linear index coding scheme. In this example, the header for linear index coding is formed by 255 bytes, as for the corresponding JPEG2000 case, and it is separately encoded with channel coding rate 0.1. Thus, the header information overhead is identical for both schemes.
A test system was used with L=3 users with capacities C1=0.3645, C2=0.6 and C3=0.9 and a target bandwidth efficiency of b=0.5 channel-coded bits per pixel. The standard test image Lena was used with a size of 1024×1024, with grey-scale 8-bit pixels. For the linear index coding scheme, 3 levels of DWT are used. The solution of the MMDP problem yields that only the shaded source blocks in
Robustness to mismatched channel capacity—as anticipated, the main advantage of linear index coding consists of its robustness to residual post-decoding erasures. In order to illustrate this aspect, we consider the case of a mismatched user with channel capacity less than the minimum channel capacity C1 for which the system is designed. We simulated the performances of the systems designed for the nominal capacities Cl, C2, C3 given before, over a BEC with capacity C varying in an interval [C0, C3], with C0<C1. For C ε[C0, C1], the system transmits at rate above the channel capacity. Therefore, even the fundamental layer (layer 1) operates “above threshold”, and it is affected by a very large number of post-decoding erasures.
For the above experiments the “kakadu” open source JPEG2000 image coder was used. The error resilience tools provided by the JPEG2000 standard (i.e., the SOP, SEGMARK, ERTERM and RESTART strategies) were enabled. In particular, with RESTART, the context statistics was restarted at the beginning of each coding pass. With ERTERM, the encoder enforces a predictable termination policy for the entropy coder. With SEGMARK, a special symbol was encoded at the end of each bit-plane. With SOP start of packet markers were inserted in front of every packet. At the decoder side the kakadu “resilient” feature was enabled, in order to obtain the best possible result. The codeblock size used was the standard in kakadu, i.e., 32×32.
It should be understood that many variations are possible based on the disclosure herein. Although features and elements are described above in particular combinations, each feature or element may be used alone without the other features and elements or in various combinations with or without other features and elements. The methods or flow charts provided herein may be implemented in a computer program, software, or firmware incorporated in a non-transitory computer-readable storage medium for execution by a general purpose computer or a processor. Examples of computer-readable storage mediums include a read only memory (ROM), a random access memory (RAM), a register, cache memory, semiconductor memory devices, magnetic media such as internal hard disks and removable disks, magneto-optical media, and optical media such as CD-ROM disks, and digital versatile disks (DVDs).
Suitable processors include, by way of example, a general purpose processor, a special purpose processor, a conventional processor, a digital signal processor (DSP), a plurality of microprocessors, one or more microprocessors in association with a DSP core, a controller, a microcontroller, Application Specific Integrated Circuits (ASICs), Field Programmable Gate Arrays (FPGAs) circuits, any other type of integrated circuit (IC), and/or a state machine. Such processors may be manufactured by configuring a manufacturing process using the results of processed hardware description language (HDL) instructions and other intermediary data including netlists (such instructions capable of being stored on non-transitory computer readable media). The results of such processing may be maskworks that are then used in a semiconductor manufacturing process to manufacture a processor which implements aspects of the present invention.
This application claims priority to earlier filed provisional application 61/416,986 filed on Jun. 18, 2010, which is incorporated herein in its entirety.
This invention was made with government support under CNS-06-25637 and NeTs-07-22073 awarded by U.S. National Science Foundation. The government has certain rights to this invention.
Number | Name | Date | Kind |
---|---|---|---|
6687296 | Sato et al. | Feb 2004 | B1 |
6738424 | Allmen et al. | May 2004 | B1 |
7305031 | Ratakonda et al. | Dec 2007 | B2 |
8286050 | Murakami et al. | Oct 2012 | B2 |
20040098659 | Bjerke et al. | May 2004 | A1 |
20060200724 | Stankovic et al. | Sep 2006 | A1 |
20080246639 | Sakai et al. | Oct 2008 | A1 |
20100157901 | Sanderovitz et al. | Jun 2010 | A1 |
20100208801 | Yamasaki | Aug 2010 | A1 |
20110052087 | Mukherjee | Mar 2011 | A1 |
Entry |
---|
M. Gastpar, B. Rimoldi, and M. Vetterli, “To code or not to code: Lossy source-channel communication revisited,” IEEE Trans. Inform. Theory, vol. 49, No. 5, pp. 1147-1158, May 2003. |
R. L. Urbanke and A. D. Wyner, “Packetizing for the erasure broadcast channel with an internet application,” in Proc. Int. Conf. Combinatorlcs, Information Theory and Statistics, Portland, ME, 1997, p. 93. |
O. Y. Bursalioglu, M. Fresia, G. Caire, and H. V. Poor, “Joint source-channel coding at the application layer,” in Proc. IEEE Data Compression Conference, Snowbird, UT, 2009. |
A. F. Dana, R. Gowaikar, R. Palanki, B. Hassibi, and M. Effros, “Capacity of wireless erasure netWorks,” IEEE Trans. Inform. Theory, vol. 52, No. 3, pp. 789-804, Mar. 2006. |
U. Mittal and N. Phamdo, “Hybrid digital-analog (IIDA) joint source-channel codes for broadcasting and robust communications,” IEEE Trans. Inform. Theory, vol. 48, No. 5, pp. 1082-1102, May 2002. |
O. Y. Bursalioglu, M. Fresia, G. Caire, and H. V. Poor, “Lossy joint source-channel coding using raptor codes,” Int. Journal of Digital Multimedia Broadcasting, vol. Article ID 124685, 18 pages, 2008. |
A. Shokrollahi, “Raptor codes,” IEEE Trans. Inform. Theory, vol. 52, No. 6, pp. 2551-2567, Jun. 2006. |
M. Fresia and G. Caire, “Combined error protection and compression with turbo codes for image transmission using a JPEG2000-like architecture,” in Proc. IEEE Int. Conf. Image Proc., Atlanta, GA, 2006, pp. 821-824. |
M. Fresia and G. Caire,“A practical approach to lossy joint source-channel coding,” Jan. 2007, submitted to IEEE Trans. Inform. Theory. |
H. Gish and J. N. Pierce, “Asymptotically efficient quantizing,” IEEE Trans. Inform. Theory, vol. 14, No. 5, pp. 676-683, Sep. 1968. |
J. Ziv, “On universal quantization,” IEEE Trans. Inform. Theory, vol. 31, No. 3, pp. 344-347, May 1985. |
M. Luby, T. Gasiba, T. Stockhammer, and M. Watson, “Reliable multimedia download delivery in cellular broadcast networks,” IEEE Trans. Broadcasting, vol. 53, No. 1, pp. 235-246, Mar. 2007. |
N. Shulman and M. Feder, “Static broadcasting,” in Proc. IEEE Int. Symp. Inform. Theory, Sorrento, Italy, 2000. |
L. S. Juhn and L. M. Tseng, “Harmonic broadcasting for video-on-demand service,” IEEE Trans. Broadcasting, vol. 43, No. 3, pp. 268-271, Sep. 1997. |
J. F. Paris, S. W. Carter, and D. D. E. Long, “Efficient broadcasting protocols for video on demand,” in Proc. Symp. Modeling, Analysis and Simulation of Computer and Telecommunication Systems, Houston, TX, 1998, pp. 127-132. |
W. H. R. Equitz and T. M Cover, “Successive refinement of information,” IEEE Trans. Inform. Theory, vol. 37, No. 2, pp. 269-275, Mar. 1991. |
K. A. Zeger and A. Gersho, “Zero redundancy channel coding in vector quantization,” Electron. Lett., vol. 23, pp. 65-55, Jun. 1987. |
K. A. Zeger and A. Gersho, “Pseudo-gray coding,” IEEE Trans. Commun., vol. 38, pp. 2147-2158, Dec. 1990. |
N. Farvardin, “A study of vector quantization for noisy channels,” IEEE Trans. Inform. Theory, vol. 36, pp. 799-809, Jul. 1990. |
N. Farvardin and V. Vaishampayan, “On the performance and complexity of channel-optimized vector quantizers,” IEEE Trans. Inform. Theory, vol. 37, pp. 155-159, Jan. 1991. |
O. Y. Bursalioglu, M. Fresia, G. Caire, and H. V. Poor, “Joint source-channel coding at the application layer for parallel Gaussian sources,” submitted to IEEE Int. Symp. Inform. Theory, 2009. |
B. Tang, A. Shen, A. Alwan, and G. Pottie, “A perceptually based embedded subband speech coder,” IEEE Trans. on Speech and Audio Processing, vol. 5, No. 2, pp. 131-140, Mar. 1997. |
M. Grangetto, B. Scanavino, and G. Olmo, “Joint source-channel iterative decoding of arithmetic codes,” Proc. IEEE Int. Conf. on Commun., pp. 886-890, 2004. |
M. Jeanne, J. Carlach, and P. Siohan, “Joint source-channel decoding of variable-length codes for convolutional codes and turbo codes,” IEEE Trans. Commun., vol. 53, No. 1, p. 11, 2005. |
L. Perros-Meilhac and C. Lamy, “Huffman tree based metric derivation for a low-complexity sequential soft VLC-decoding,” in Proc. IEEE Int. Conf. on Commun., New York, NY, 2002, pp. 783-787. |
M. Fresia and G. Caire, “A practical approach to lossy joint source channel coding,” in Proc. Information Theory and Applications Workshop, University of California, San Diego, La Jolla, CA, 2007. |
Number | Date | Country | |
---|---|---|---|
20120039385 A1 | Feb 2012 | US |
Number | Date | Country | |
---|---|---|---|
61356404 | Jun 2010 | US |