123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- /* Copyright (C) 2007 Jean-Marc Valin
- File: testresample2.c
- Testing the resampling code
- Redistribution and use in source and binary forms, with or without
- modification, are permitted provided that the following conditions are
- met:
- 1. Redistributions of source code must retain the above copyright notice,
- this list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
- 3. The name of the author may not be used to endorse or promote products
- derived from this software without specific prior written permission.
- THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
- IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
- OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
- INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
- SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
- STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
- ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- POSSIBILITY OF SUCH DAMAGE.
- */
- #ifdef HAVE_CONFIG_H
- #include "config.h"
- #endif
- #include "speex/speex_resampler.h"
- #include <stdio.h>
- #include <math.h>
- #include <stdlib.h>
- #define PERIOD 32
- #define INBLOCK 1024
- #define RATE 48000
- int main()
- {
- spx_uint32_t i;
- float *fin, *fout;
- int rate = 1000, off = 0, avail = INBLOCK;
- SpeexResamplerState *st = speex_resampler_init(1, RATE, RATE, 4, NULL);
- speex_resampler_set_rate(st, RATE, rate);
- speex_resampler_skip_zeros(st);
- fin = malloc(INBLOCK*2*sizeof(float));
- for (i=0; i<INBLOCK*2;i++)
- fin[i] = sinf ((float)i/PERIOD * 2 * M_PI) * 0.9;
- fout = malloc(INBLOCK*4*sizeof(float));
- while (1)
- {
- spx_uint32_t in_len;
- spx_uint32_t out_len;
- in_len = avail;
- out_len = (in_len * rate + RATE-1) / RATE;
- fprintf (stderr, "%d %d %d %d -> ", rate, off, in_len, out_len);
- speex_resampler_process_float(st, 0, fin + off, &in_len, fout, &out_len);
- fprintf (stderr, "%d %d\n", in_len, out_len);
- off += in_len;
- avail = avail - in_len + INBLOCK;
- if (off >= INBLOCK)
- off -= INBLOCK;
- fwrite(fout, sizeof(float), out_len, stdout);
- rate += 100;
- if (rate > 128000)
- break;
- speex_resampler_set_rate(st, RATE, rate);
- }
- speex_resampler_destroy(st);
- free(fin);
- free(fout);
- return 0;
- }
|