2011-05-03 2 views
-1

안녕하세요! 에코 제거 처리를 위해 float 샘플을 사용하는 방법은 무엇입니까?플로트 샘플을 처리하기 위해 speex 반향 제거기를 어떻게 적응시킬 수 있습니까?

void float_speex_echo_cancellation(SpeexEchoState *st, const float rec[], const float play[], float out[]); 

void speex_echo_cancellation(SpeexEchoState *st, const spx_int16_t *rec, const spx_int16_t *play, spx_int16_t *out); 

로부터

... 
     for (i=0;i<st->frame_size;i++) 
     { 
     spx_word32_t tmp_out; 
     tmp_out = SUB32(EXTEND32(st->input[chan*st->frame_size+i]), EXTEND32(st->e[chan*N+i+st->frame_size])); 
     tmp_out = ADD32(tmp_out, EXTEND32(MULT16_16_P15(st->preemph, st->memE[chan]))); 

     if (in[i*C+chan] <= -32000 || in[i*C+chan] >= 32000) 
     { 
     if (st->saturated == 0) 
      st->saturated = 1; 
     } 

     **out[i*C+chan] = (spx_int16_t)WORD2INT(tmp_out);** 

     st->memE[chan] = tmp_out; 
     } 
... 

... 

    for (i=0;i<st->frame_size;i++) 
      { 
      spx_word32_t tmp_out; 
      tmp_out = SUB32(EXTEND32(st->input[chan*st->frame_size+i]), EXTEND32(st->e[chan*N+i+st->frame_size])); 
      tmp_out = ADD32(tmp_out, EXTEND32(MULT16_16_P15(st->preemph, st->memE[chan]))); 

      if (in[i*C+chan] <= -32000 || in[i*C+chan] >= 32000) 
      { 
      if (st->saturated == 0) 
       st->saturated = 1; 
      } 

      **out[i*C+chan] = /*(spx_int16_t)WORD2INT(*/tmp_out*/)*/;** 

      st->memE[chan] = tmp_out; 
      } 
    ... 
,691,363에서 : I 중앙 기능의 인터페이스 및 바디를 변경하려고210

static inline void filter_dc_notch16(const spx_int16_t *in, spx_word16_t radius, spx_word16_t *out, int len, spx_mem_t *mem, int stride) 
{ 
    int i; 
    spx_word16_t den2; 
    den2 = (spx_word16_t)(radius*radius + .7f*(1.f-radius)*(1.f-radius)); 
    for (i=0;i<len;i++) 
    { 
     spx_int16_t vin = in[i*stride]; 
     spx_word32_t vout = mem[0] + SHL32(EXTEND32(vin),15); 
     mem[0] = mem[1] + 2*(-vin + radius*vout); 
     mem[1] = SHL32(EXTEND32(vin),15) - MULT16_32_Q15(den2,vout); 
     out[i] = SATURATE32(PSHR32(MULT16_32_Q15(radius,vout),15),32767); 
    } 
} 

에서

static inline void float_filter_dc_notch16(const /*spx_int16_t*/spx_word16_t *in, spx_word16_t radius, spx_word16_t *out, int len, spx_mem_t *mem, int stride) 
{ 
    int i; 
    spx_word16_t den2; 
    den2 = /*(spx_word16_t)*/(radius*radius + .7f*(1.f-radius)*(1.f-radius)); 
    for (i=0;i<len;i++) 
    { 
     /*spx_int16_t*/spx_word16_t vin = in[i*stride]; 
     spx_word32_t vout = mem[0] + SHL32(EXTEND32(vin),15); 
     mem[0] = mem[1] + 2*(-vin + radius*vout); 
     mem[1] = SHL32(EXTEND32(vin),15) - MULT16_32_Q15(den2,vout); 
     out[i] = /*SATURATE32(*/PSHR32(MULT16_32_Q15(radius,vout),15)/*,32767)*/; 
    } 
} 

하려면 그래서, 짧은 INT에 플로트 식의 출력 결과로부터 전환을 방지하지만, 이제는 경고 얻을 : ("에코를

speex_warning을 취소 원이 재미있는 행동을 시작하고 때 리거나 (재설정). 그것은 지금 작동합니다 맹세 "); screwed_up 매개 변수 (50 개) 값을 갖는하고 모든 밖으로 샘플을 제로로 설정하는 서명> ST-가리키는

:.?

... 

if (!(Syy>=0 && Sxx>=0 && See >= 0) 
    || !(Sff < N*1e9 && Syy < N*1e9 && Sxx < N*1e9) 
) 

{ st->screwed_up += 50; for (i=0;iframe_size*C;i++) out[i] = 0; } 

... 

내가

을 수행 할 수있는 작업을
enter code here 

답변

1

은 왜 부동의 샘플을 사용하고자 할 표준 리니어 PCM 오디오가 선택한 비트 레이트에 따라 정수 샘플로 표시됩니다 -. 그래서 8 비트, 16 비트 및

어디에서 그 의견을 얻습니까?

내가 너라면 반바지에 담긴 제품을 변환하여 Speex에 제공하여 작업 할 수 있도록 할 것입니다.

관련 문제