[Speex-dev] Resampler saturation, blackfin performance

Jean-Marc Valin jean-marc.valin at usherbrooke.ca
Sun Jun 14 16:16:18 PDT 2009


Stephane Lesage a écrit :
>> -----Message d'origine-----
>> De : Jean-Marc Valin [mailto:jean-marc.valin at usherbrooke.ca] 
>> Envoyé : dimanche, 14. juin 2009 20:46
>> À : Stephane Lesage
>> Cc : speex-dev at xiph.org
>> Objet : Re: [Speex-dev] Resampler saturation
>>
>> Just to make sure I understand, the two patches you sent are 
>> two different ways to fix the problem, with the only 
>> difference being that resample.patch converts the "unrolled 
>> by four" loop into a plain one that's easier on DSPs, right?
> 
> Yes exactly, plus a little explanation in comments.
> I really have no idea of the performance difference on x86. But I think gcc/msvc can unroll.
> Up to you. Anyway I can OVERRIDE_INNER_PRODUCT_SINGLE.

OK, I guess I'll apply resample.patch considering that we already have
an SSE version (the split in four was for SSE anyway).

> Talking about performance (still using generic version with VDSP compiler):

You'll likely see a difference just by optimising the MULT16_32_Q15() macro.

> 1. I got a pretty good boost by using a scratch buffer in SRAM.

Normally, all the data should end up in L1 cache, so it's surprising
that you see a difference with using SRAM. Are you sure your cache isn't
configured as write-through?

> 2. Wideband Encode+Decode takes 79.1 + 7.2 MIPS on my BF536 400/133 Mhz
> 3. Profiler says:
> vq_nbest                  33.05%
> vq_nbest_sign             11.12%

You should be able to get a big boost in performance just by optimising
the N=1 case for vq_nbest() and vq_nbest_sign().

> filter_mem16               4.14%

If you look at the Blackfin-optimised version, it actually uses a
different algorithm (that does 2 MACs/cycle) for this one (assuming you
place the arrays in two banks, which I don't do yet).

> inner_prod                 4.07%

Again, the Blackfin-optimised version does it with 2 MACs/cycle.

> iir_mem16                  2.75%
> qmf_synth                  2.32%
> lsp_to_lpc                 2.32%
> open_loop_nbest_pitch      1.41%
> compute_impulse_response   1.37%
> qmf_decomp                 1.28%
> lpc_to_lsp                 1.26%
> fir_mem16                  1.16%
> speex_bits_pack            1.07%
> speex_bits_unpack_unsigned 0.86%
> compute_rms16              0.79%
> 
> 4. I'm using the echo-canceller + preprocessor,
> I'd really like to improve performance here:
> - I would like to use ADI's FFT, but it's limited to powers of 2,
> is it safe to enable "Round ps_size down to the nearest power of two"  in the preproc ?

It should be (unless I broke it!). Otherwise, nothing prevents you from
doing all that processing on power-of-two frames and then doing a bit of
buffering for the codec.

> can we do the same trick with the echo-canceller for window_size ?

If you want to use the echo canceller with a power-of-two FFT, the frame
size really needs to be a power-of-two

> - are there buffers who could be placed in scratch memory ?
> (I don't see any speex_scratch_alloc inthere)

I don't understand your question.

	Jean-Marc



More information about the Speex-dev mailing list