[FFmpeg-devel] [PATCH] G.729 and G.729D decoders

Vladimir Voroshilov voroshil
Sun Apr 20 19:11:16 CEST 2008


On Sun, Apr 20, 2008 at 10:00 PM, Michael Niedermayer <michaelni at gmx.at> wrote:
> On Sun, Apr 20, 2008 at 08:18:20PM +0700, Vladimir Voroshilov wrote:
>  > Hi, Michael
>  >
>  > On Sun, Apr 20, 2008 at 6:22 PM, Michael Niedermayer <michaelni at gmx.at> wrote:
>  > > On Sun, Apr 20, 2008 at 12:31:44PM +0700, Vladimir Voroshilov wrote:
>  > >  > Hi, Michael.
>  >
>  > [...]
>  >
>  > >  > I hope, lookup tables and build api can be separated.
>  > >  > Otherwise i can't create uncompressed <100k patch.
>  > >
>  > >  Well this patch started out at 77k and then grew to 98k during review
>  > >  now its even with compressed tables over 110k
>  > >  77k is already very large and hard to review
>  > >  Iam simply drawing a line and rejecting it until it returns to <100k
>  > >  It was possible in previous iterations so it should still be. If not
>  > >  which of my change requests caused such size increase?
>  > >  You have added support for g729d thats nice but it has to be
>  > >  split into a seperate patch. I dont know if it also makes sense to
>  > >  split it into several files.
>  >
>  > 1. G.729A -> G.729 added 12k of source code (due to huge long-term
>  > filter, large tilt-compensation filter and additional lookup tables
>  > for them)
>  > 2. G.729D support added additionally about 8k
>  >
>  > Here is 93k size G.729-only patch.
>  > I don't know what else can be removed from it.
>
>  your first patch was 77k base64 encoded this is 122k base64 encoded

Sigh. first patch was floating-point and had size 77k (base64)
First fixed-point decoder was 95k long (base64)

>
>  I will try to review it but considering the size this will take time
>  This could easily take a year until it reaches svn ...
>  The bigger the patch the more iterations it needs and the longer
>  each review-fix-resend iteration will take. Also the bigger the more
>  exhausted one gets during the review and thus the more things are missed.
>  Which will then need more iterations.
>
>
>  So i strongly suggest that you find a way to split it.
>
>  For example if i just grep for lsp i do find hits in wmadec and vorbis_dec,
>  maybe that can be factored out in a common lsp handling code and
>  seperate patch. I do not know if there are other such things but if there
>  are they definitly should be factored out.

1. both of them are floating point.
2. none of their tables are similar to mine.

> Such common code should not be
>  duplicated in each decoder and as a side effect it also allows some patch
>  spliting.

Sure.

> Also there likely are a few
>  common things with amr / qcelp (see soc svn) these as well can go in
>  seperate files and patches.
>  (of course theres no need to support the amr/qcelp variants but the API
>  for such common code should allow support for them to be added, also
>  robert and reynaldo might be willing to help with this, after all this
>  would simplify getting their decoders into svn)

Yes, LP decoding in soc/amr looks very similar to mine.
How those can be joined?
What about creating new file (celp.c for example) ?

Quick look shows me that lsf2lsp, reorder_lsp can be merged.

decode_*_pulses_* routines can be merged too by using lookup tables in amr
instead of hardcoded shifts  and multiplications (see mine
decode_fc_vector, unified
routine in cost of several additional lookup tables).

What patches should i prepare?
One for celp.c and one for amr soc project in the same mail (in
separate thread, of course)?

-- 
Regards,
Vladimir Voroshilov     mailto:voroshil at gmail.com
JID: voroshil at gmail.com, voroshil at jabber.ru
ICQ: 95587719




More information about the ffmpeg-devel mailing list