Bump version to 0.6.0 and increase bitstream version.
[opus.git] / libcelt / modes.h
index a047822..0957261 100644 (file)
@@ -1,4 +1,4 @@
-/* (C) 2007 Jean-Marc Valin, CSIRO
+/* (C) 2007-2008 Jean-Marc Valin, CSIRO
 */
 /*
    Redistribution and use in source and binary forms, with or without
 
 #include "celt_types.h"
 #include "celt.h"
+#include "arch.h"
+#include "mdct.h"
+#include "psy.h"
+#include "pitch.h"
+
+#define CELT_BITSTREAM_VERSION 0x80000008
+
+#ifdef STATIC_MODES
+#include "static_modes.h"
+#endif
+
+#define MAX_PERIOD 1024
+
+#ifndef CHANNELS
+# ifdef DISABLE_STEREO
+#  define CHANNELS(mode) (1)
+# else
+#  define CHANNELS(mode) ((mode)->nbChannels)
+# endif
+#endif
+
+#define MDCT(mode) (&(mode)->mdct)
+
+#ifndef OVERLAP
+#define OVERLAP(mode) ((mode)->overlap)
+#endif
+
+#ifndef FRAMESIZE
+#define FRAMESIZE(mode) ((mode)->mdctSize)
+#endif
 
 /** Mode definition (opaque)
  @brief Mode definition 
  */
 struct CELTMode {
+   celt_uint32_t marker_start;
+   celt_int32_t Fs;
    int          overlap;
    int          mdctSize;
-   int          nbMdctBlocks;
    int          nbChannels;
    
    int          nbEBands;
    int          nbPBands;
    int          pitchEnd;
    
-   const int   *eBands;   /**< Definition for each "pseudo-critical band" */
-   const int   *pBands;   /**< Definition of the bands used for the pitch */
+   const celt_int16_t   *eBands;   /**< Definition for each "pseudo-critical band" */
+   const celt_int16_t   *pBands;   /**< Definition of the bands used for the pitch */
    
-   float        ePredCoef;/**< Prediction coefficient for the energy encoding */
+   celt_word16_t ePredCoef;/**< Prediction coefficient for the energy encoding */
    
    int          nbAllocVectors; /**< Number of lines in the matrix below */
-   const int   *allocVectors;   /**< Number of bits in each band for several rates */
+   const celt_int16_t   *allocVectors;   /**< Number of bits in each band for several rates */
    
-   const int * const *bits; /**< Cache for pulses->bits mapping in each band */
+   const celt_int16_t * const *bits; /**< Cache for pulses->bits mapping in each band */
+
+   /* Stuff that could go in the {en,de}coder, but we save space this way */
+   mdct_lookup mdct;
+   kiss_fftr_cfg fft;
 
+   const celt_word16_t *window;
+
+   int         nbShortMdcts;
+   int         shortMdctSize;
+   mdct_lookup shortMdct;
+   const celt_word16_t *shortWindow;
+
+   struct PsyDecay psy;
+
+   int *prob;
+   celt_uint32_t marker_end;
 };
 
+int check_mode(const CELTMode *mode);
+
 #endif