From d03b2503696cb296be7e309f1bcdc69b7da3204a Mon Sep 17 00:00:00 2001 From: Jyrki Alakuijala Date: Mon, 2 Jul 2012 20:31:09 +0000 Subject: [PATCH] fixing the findings by Frederic Kayser to the bitstream spec Change-Id: I4bcc428412dd4c21675d90159771e2e0b338ecf3 --- doc/webp-lossless-bitstream-spec.txt | 35 ++++++++++++++-------------- 1 file changed, 18 insertions(+), 17 deletions(-) diff --git a/doc/webp-lossless-bitstream-spec.txt b/doc/webp-lossless-bitstream-spec.txt index 24095a91..bd174fd4 100644 --- a/doc/webp-lossless-bitstream-spec.txt +++ b/doc/webp-lossless-bitstream-spec.txt @@ -130,7 +130,7 @@ internally. Broadly, a WebP lossless image contains header data, transform information and actual image data. Headers contain width and height of -the image. A WebP lossless image can go through five different types of +the image. A WebP lossless image can go through four different types of transformation before being entropy encoded. The transform information in the bitstream contains the data required to apply the respective inverse transforms. @@ -781,7 +781,7 @@ prefixes, and the result of this coding is further Huffman coded. For every pixel (x, y) in the image, there is a definition of which entropy code to use. First, there is an integer called 'meta Huffman -code' that can be obtained from a subresolution 2D image. This +code' that can be obtained from the entropy image. This meta Huffman code identifies a set of five Huffman codes, one for green (along with length codes and color cache codes), one for each of red, blue and alpha, and one for distance. The Huffman codes are identified @@ -886,7 +886,7 @@ codes to the number of meta Huffman codes. There are two ways to code the meta Huffman codes, indicated by one bit for the ARGB image and is an implicit zero, i.e., not present in the -stream for all predictor images and Huffman image itself. +stream for all transform images and the entropy image itself. If this bit is zero, there is only one meta Huffman code, using Huffman codes 0, 1, 2, 3 and 4 for green, alpha, red, blue and distance, @@ -953,8 +953,8 @@ of pixels (xsize * ysize). ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ::= - ::= () | - + ::= (); + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ @@ -964,23 +964,24 @@ of pixels (xsize * ysize). ::= 1-bit | 0-bit ::= | | | - ::= 2-bit value 0; 4-bit sub-pixel code | - ::= 2-bit value 1; 4-bit sub-pixel code | + ::= 2-bit value 0; + ::= 3-bit sub-pixel code | + ::= 2-bit value 1; + ::= 3-bit sub-pixel code | ::= 2-bit value 2 - ::= 2-bit value 3; 8-bit color count | + ::= 2-bit value 3; + ::= 8-bit color count; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ #### Structure of the Image Data ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - ::= - - ::= 1-bit value 0 | - (1-bit value 1; - ) - ::= 4-bit subsample value; - ::= 4-bit length; meta Huffman size (subtracted by 2). + ::= + ::= + ::= 1-bit value 0 | + (1-bit value 1; ) + ::= 3-bit subsample value; ::= 1 bit value 0 | (1-bit value 1; 4-bit value for color cache size) ::= | @@ -996,7 +997,7 @@ A possible example sequence: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1-bit value 1 -1-bit value 11-bit value 0 - +1-bit value 11-bit value 0 + ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~