[Theora-dev] Changing the IDCT spec

Aaron Colwell acolwell at real.com
Wed Feb 16 09:30:59 PST 2005


Option 1 sounds good to me. I haven't implemented the IDCT for Blackfin yet,
but I'm sure that this will help with that effort.

Aaron

On Fri, Feb 11, 2005 at 02:28:33PM -0500, Timothy B. Terriberry wrote:
> So, in preparation for some decoder optimization work planned by Rudolf 
>  Marek, the subject of the size of the registers needed in the IDCT 
> came up.
> 
> The current spec language ensures that the result is exactly compatible 
> with the C code for VP3. This language requires that some of the 
> arguments to the multiplies be 17 or 18 bits, because they need to hold 
> the sum or difference of two 16-bit numbers. This necessitates using 
> 32-bit registers, which greatly reduces potential parallelism for SIMD 
> instructions (not to mention making an implementation much more 
> complicated on embedded chipsets with 16-bit registers).
> 
> However, upon reviewing VP3's own MMX routines, I discovered that they 
> used 16-bit registers anyway. Thus, in VP3 where the code IS the spec, 
> the code still doesn't match the spec.
> 
> Now, I want to emphasize, in practical terms, the differences have very 
> little real effect. Given normal pixel values, the resulting DCT 
> coefficients should not even come close to overflowing the registers 
> during the IDCT (there are about 3 bits to spare). Even with some pretty 
> severe quantization errors, that seems to be enough headroom.
> 
> However, the specification does not specify the encoder's operation, it 
> specify the decoder's. It is possible to store coefficients in the 
> bitstream that would cause overflow, and we need to standardize what to 
> do in such cases. When I wrote the section in the spec, I took the 
> approach of "do what the code does, no matter how much it hurts 
> optimization", but knowing now that the code does two different things, 
> we have a choice.
> 
> However, the spec has now been included in an official release (alpha4), 
> and I know several people have begun or completed independent 
> implementations (e.g., Andrey Filippov's FPGA encoder, Robert 
> Brautigam's Java port, for sure, and I remember some talk of a DSP stamp 
> between either Aaron Colwell and the Fluendo folks). So I don't want 
> make such a significant change to the language of the spec without 
> soliciting input from the people it will affect.
> 
> So, to summarize, there are two choices:
> 1) Truncate the result of each intermediate step in the IDCT to 16 bits, 
> providing for better SIMD and 16-bit architecture optimization, but 
> requiring slightly more work in a 32-bit C implementation, or
> 2) Keep the current language, allowing some intermediate results to grow 
> to 17 or 18 bits, requiring 32-bit registers.
> 
> Either choice should have no real effect on content encoded with any of 
> the encoders I am aware of. Both are equally compatible with existing 
> VP3 content, as different VP3 codepaths follow both approaches. If 
> anything, the first approach is probably used more often since most PCs 
> from the last 9 years have had some kind of MMX support.
> 
> Thoughts? Opinions?
> _______________________________________________
> Theora-dev mailing list
> Theora-dev at xiph.org
> http://lists.xiph.org/mailman/listinfo/theora-dev
> 


More information about the Theora-dev mailing list