Blame libcelt/testcelt.c

Packit 664db3
/* (C) 2007 Jean-Marc Valin, CSIRO
Packit 664db3
*/
Packit 664db3
/*
Packit 664db3
   Redistribution and use in source and binary forms, with or without
Packit 664db3
   modification, are permitted provided that the following conditions
Packit 664db3
   are met:
Packit 664db3
   
Packit 664db3
   - Redistributions of source code must retain the above copyright
Packit 664db3
   notice, this list of conditions and the following disclaimer.
Packit 664db3
   
Packit 664db3
   - Redistributions in binary form must reproduce the above copyright
Packit 664db3
   notice, this list of conditions and the following disclaimer in the
Packit 664db3
   documentation and/or other materials provided with the distribution.
Packit 664db3
   
Packit 664db3
   - Neither the name of the Xiph.org Foundation nor the names of its
Packit 664db3
   contributors may be used to endorse or promote products derived from
Packit 664db3
   this software without specific prior written permission.
Packit 664db3
   
Packit 664db3
   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 664db3
   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 664db3
   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 664db3
   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
Packit 664db3
   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
Packit 664db3
   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
Packit 664db3
   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
Packit 664db3
   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
Packit 664db3
   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
Packit 664db3
   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
Packit 664db3
   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 664db3
*/
Packit 664db3
Packit 664db3
#ifdef HAVE_CONFIG_H
Packit 664db3
#include "config.h"
Packit 664db3
#endif
Packit 664db3
Packit 664db3
#include "celt.h"
Packit 664db3
#include "arch.h"
Packit 664db3
#include <stdio.h>
Packit 664db3
#include <stdlib.h>
Packit 664db3
#include <math.h>
Packit 664db3
#include <string.h>
Packit 664db3
Packit 664db3
int main(int argc, char *argv[])
Packit 664db3
{
Packit 664db3
   char *inFile, *outFile;
Packit 664db3
   FILE *fin, *fout;
Packit 664db3
   CELTMode *mode=NULL;
Packit 664db3
   CELTEncoder *enc;
Packit 664db3
   CELTDecoder *dec;
Packit 664db3
   int len;
Packit 664db3
   celt_int32_t frame_size, channels;
Packit 664db3
   int bytes_per_packet;
Packit 664db3
   unsigned char data[1024];
Packit 664db3
   int rate;
Packit 664db3
   int complexity;
Packit 664db3
#if !(defined (FIXED_POINT) && defined(STATIC_MODES))
Packit 664db3
   int i;
Packit 664db3
   double rmsd = 0;
Packit 664db3
#endif
Packit 664db3
   int count = 0;
Packit 664db3
   celt_int32_t skip;
Packit 664db3
   celt_int16_t *in, *out;
Packit 664db3
   if (argc != 9 && argc != 8 && argc != 7)
Packit 664db3
   {
Packit 664db3
      fprintf (stderr, "Usage: testcelt <rate> <channels> <frame size> <bytes per packet> [<complexity> [packet loss rate]] <input> <output>\n");
Packit 664db3
      return 1;
Packit 664db3
   }
Packit 664db3
   
Packit 664db3
   rate = atoi(argv[1]);
Packit 664db3
   channels = atoi(argv[2]);
Packit 664db3
   frame_size = atoi(argv[3]);
Packit 664db3
   mode = celt051_mode_create(rate, channels, frame_size, NULL);
Packit 664db3
   celt051_mode_info(mode, CELT_GET_LOOKAHEAD, &skip);
Packit 664db3
   
Packit 664db3
   if (mode == NULL)
Packit 664db3
   {
Packit 664db3
      fprintf(stderr, "failed to create a mode\n");
Packit 664db3
      return 1;
Packit 664db3
   }
Packit 664db3
   
Packit 664db3
   bytes_per_packet = atoi(argv[4]);
Packit 664db3
   if (bytes_per_packet < 0 || bytes_per_packet > 200)
Packit 664db3
   {
Packit 664db3
      fprintf (stderr, "bytes per packet must be between 10 and 200\n");
Packit 664db3
      return 1;
Packit 664db3
   }
Packit 664db3
Packit 664db3
   inFile = argv[argc-2];
Packit 664db3
   fin = fopen(inFile, "rb");
Packit 664db3
   if (!fin)
Packit 664db3
   {
Packit 664db3
      fprintf (stderr, "Could not open input file %s\n", argv[argc-2]);
Packit 664db3
      return 1;
Packit 664db3
   }
Packit 664db3
   outFile = argv[argc-1];
Packit 664db3
   fout = fopen(outFile, "wb+");
Packit 664db3
   if (!fout)
Packit 664db3
   {
Packit 664db3
      fprintf (stderr, "Could not open output file %s\n", argv[argc-1]);
Packit 664db3
      return 1;
Packit 664db3
   }
Packit 664db3
   
Packit 664db3
   /* Use mode4 for stereo and don't forget to change the value of CHANNEL above */
Packit 664db3
   enc = celt051_encoder_create(mode);
Packit 664db3
   dec = celt051_decoder_create(mode);
Packit 664db3
Packit 664db3
   if (argc>7)
Packit 664db3
   {
Packit 664db3
      complexity=atoi(argv[5]);
Packit 664db3
      celt051_encoder_ctl(enc,CELT_SET_COMPLEXITY(complexity));
Packit 664db3
   }
Packit 664db3
   
Packit 664db3
   celt051_mode_info(mode, CELT_GET_FRAME_SIZE, &frame_size);
Packit 664db3
   celt051_mode_info(mode, CELT_GET_NB_CHANNELS, &channels);
Packit 664db3
   in = (celt_int16_t*)malloc(frame_size*channels*sizeof(celt_int16_t));
Packit 664db3
   out = (celt_int16_t*)malloc(frame_size*channels*sizeof(celt_int16_t));
Packit 664db3
   while (!feof(fin))
Packit 664db3
   {
Packit 664db3
      fread(in, sizeof(short), frame_size*channels, fin);
Packit 664db3
      if (feof(fin))
Packit 664db3
         break;
Packit 664db3
      len = celt051_encode(enc, in, in, data, bytes_per_packet);
Packit 664db3
      if (len <= 0)
Packit 664db3
      {
Packit 664db3
         fprintf (stderr, "celt051_encode() returned %d\n", len);
Packit 664db3
         return 1;
Packit 664db3
      }
Packit 664db3
      /* This is for simulating bit errors */
Packit 664db3
#if 0
Packit 664db3
      int errors = 0;
Packit 664db3
      int eid = 0;
Packit 664db3
      /* This simulates random bit error */
Packit 664db3
      for (i=0;i
Packit 664db3
      {
Packit 664db3
         if (rand()%atoi(argv[8])==0)
Packit 664db3
         {
Packit 664db3
            if (i<64)
Packit 664db3
            {
Packit 664db3
               errors++;
Packit 664db3
               eid = i;
Packit 664db3
            }
Packit 664db3
            data[i/8] ^= 1<<(7-(i%8));
Packit 664db3
         }
Packit 664db3
      }
Packit 664db3
      if (errors == 1)
Packit 664db3
         data[eid/8] ^= 1<<(7-(eid%8));
Packit 664db3
      else if (errors%2 == 1)
Packit 664db3
         data[rand()%8] ^= 1<
Packit 664db3
#endif
Packit 664db3
#if 1 /* Set to zero to use the encoder's output instead */
Packit 664db3
      /* This is to simulate packet loss */
Packit 664db3
      if (argc==10 && rand()%1000
Packit 664db3
      /*if (errors && (errors%2==0))*/
Packit 664db3
         celt051_decode(dec, NULL, len, out);
Packit 664db3
      else
Packit 664db3
         celt051_decode(dec, data, len, out);
Packit 664db3
#else
Packit 664db3
      for (i=0;i
Packit 664db3
         out[i] = in[i];
Packit 664db3
#endif
Packit 664db3
#if !(defined (FIXED_POINT) && defined(STATIC_MODES))
Packit 664db3
      for (i=0;i
Packit 664db3
      {
Packit 664db3
         rmsd += (in[i]-out[i])*1.0*(in[i]-out[i]);
Packit 664db3
         /*out[i] -= in[i];*/
Packit 664db3
      }
Packit 664db3
#endif
Packit 664db3
      count++;
Packit 664db3
      fwrite(out+skip, sizeof(short), (frame_size-skip)*channels, fout);
Packit 664db3
      skip = 0;
Packit 664db3
   }
Packit 664db3
   PRINT_MIPS(stderr);
Packit 664db3
   
Packit 664db3
   celt051_encoder_destroy(enc);
Packit 664db3
   celt051_decoder_destroy(dec);
Packit 664db3
   fclose(fin);
Packit 664db3
   fclose(fout);
Packit 664db3
#if !(defined (FIXED_POINT) && defined(STATIC_MODES))
Packit 664db3
   if (rmsd > 0)
Packit 664db3
   {
Packit 664db3
      rmsd = sqrt(rmsd/(1.0*frame_size*channels*count));
Packit 664db3
      fprintf (stderr, "Error: encoder doesn't match decoder\n");
Packit 664db3
      fprintf (stderr, "RMS mismatch is %f\n", rmsd);
Packit 664db3
      return 1;
Packit 664db3
   } else {
Packit 664db3
      fprintf (stderr, "Encoder matches decoder!!\n");
Packit 664db3
   }
Packit 664db3
#endif
Packit 664db3
   celt051_mode_destroy(mode);
Packit 664db3
   free(in);
Packit 664db3
   free(out);
Packit 664db3
   return 0;
Packit 664db3
}
Packit 664db3