Decoder structure
authorJean-Marc Valin <jean-marc.valin@octasic.com>
Wed, 30 Jun 2010 19:03:35 +0000 (15:03 -0400)
committerJean-Marc Valin <jean-marc.valin@octasic.com>
Wed, 30 Jun 2010 19:03:35 +0000 (15:03 -0400)
src/hybrid.h
src/hybrid_decoder.c [new file with mode: 0644]
src/hybrid_decoder.h [new file with mode: 0644]
src/hybrid_encoder.c
src/test_hybrid.c

index 37d7f02..ae03293 100644 (file)
 */
 
 typedef struct HybridEncoder HybridEncoder;
+typedef struct HybridDecoder HybridDecoder;
 
 HybridEncoder *hybrid_encoder_create();
 
-int hybrid_encode(HybridEncoder *st, short *pcm, int frame_size,
+int hybrid_encode(HybridEncoder *st, const short *pcm, int frame_size,
                unsigned char *data, int bytes_per_packet);
 
 void hybrid_encoder_destroy(HybridEncoder *st);
+
+
+HybridDecoder *hybrid_decoder_create();
+int hybrid_decode(HybridDecoder *st, const unsigned char *data, int len,
+               short *pcm, int frame_size);
+
+void hybrid_decoder_destroy(HybridDecoder *st);
+
diff --git a/src/hybrid_decoder.c b/src/hybrid_decoder.c
new file mode 100644 (file)
index 0000000..2617faf
--- /dev/null
@@ -0,0 +1,88 @@
+/* Copyright (c) 2010 Xiph.Org Foundation
+   Written by Jean-Marc Valin */
+/*
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions
+   are met:
+
+   - Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+   - 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.
+
+   - Neither the name of the Xiph.org Foundation nor the names of its
+   contributors may be used to endorse or promote products derived from
+   this software without specific prior written permission.
+
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+   ``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 FOUNDATION OR
+   CONTRIBUTORS 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 <stdlib.h>
+#include "hybrid_decoder.h"
+#include "celt/libcelt/entdec.h"
+
+
+HybridDecoder *hybrid_decoder_create()
+{
+       HybridDecoder *st;
+
+       st = malloc(sizeof(HybridDecoder));
+
+       /* FIXME: Initialize SILK encoder here */
+       st->silk_dec = NULL;
+
+       /* We should not have to create a CELT mode for each encoder state */
+       st->celt_mode = celt_mode_create(48000, 960, NULL);
+       /* Initialize CELT encoder */
+       st->celt_dec = celt_decoder_create(st->celt_mode, 1, NULL);
+
+       return st;
+
+}
+int hybrid_decode(HybridDecoder *st, const unsigned char *data,
+               int len, short *pcm, int frame_size)
+{
+       int celt_ret;
+       ec_dec dec;
+       ec_byte_buffer buf;
+
+       ec_byte_readinit(&buf,(unsigned char*)data,len);
+       ec_dec_init(&dec,&buf);
+
+       /* FIXME: Call SILK encoder for the low band */
+
+       /* This should be adjusted based on the SILK bandwidth */
+       celt_decoder_ctl(st->celt_dec, CELT_SET_START_BAND(13));
+
+       /* Encode high band with CELT */
+       celt_ret = celt_decode_with_ec(st->celt_dec, data, len, pcm, NULL, frame_size, &dec);
+
+       return celt_ret;
+
+}
+
+void hybrid_decoder_destroy(HybridDecoder *st)
+{
+       /* FIXME: Destroy SILK encoder state */
+
+       celt_decoder_destroy(st->celt_dec);
+       celt_mode_destroy(st->celt_mode);
+
+       free(st);
+}
diff --git a/src/hybrid_decoder.h b/src/hybrid_decoder.h
new file mode 100644 (file)
index 0000000..85a7b21
--- /dev/null
@@ -0,0 +1,46 @@
+/* Copyright (c) 2010 Xiph.Org Foundation
+   Written by Jean-Marc Valin */
+/*
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions
+   are met:
+
+   - Redistributions of source code must retain the above copyright
+   notice, this list of conditions and the following disclaimer.
+
+   - 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.
+
+   - Neither the name of the Xiph.org Foundation nor the names of its
+   contributors may be used to endorse or promote products derived from
+   this software without specific prior written permission.
+
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+   ``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 FOUNDATION OR
+   CONTRIBUTORS 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.
+*/
+
+#ifndef HYBRID_DECODER_H
+#define HYBRID_DECODER_H
+
+#include "celt/libcelt/celt.h"
+#include "hybrid.h"
+
+struct HybridDecoder {
+       CELTMode    *celt_mode;
+       CELTDecoder *celt_dec;
+       void        *silk_dec;
+};
+
+
+#endif /* HYBRID_DECODER_H */
+
index e68baa7..778a2af 100644 (file)
@@ -55,7 +55,7 @@ HybridEncoder *hybrid_encoder_create()
        return st;
 }
 
-int hybrid_encode(HybridEncoder *st, short *pcm, int frame_size,
+int hybrid_encode(HybridEncoder *st, const short *pcm, int frame_size,
                unsigned char *data, int bytes_per_packet)
 {
        int celt_ret;
index f49ea76..440c65d 100644 (file)
@@ -49,6 +49,7 @@ int main(int argc, char *argv[])
    char *inFile, *outFile;
    FILE *fin, *fout;
    HybridEncoder *enc;
+   HybridDecoder *dec;
    int len;
    int frame_size, channels;
    int bytes_per_packet;
@@ -93,7 +94,7 @@ int main(int argc, char *argv[])
    }
 
    enc = hybrid_encoder_create();
-   /*dec = hybrid_decoder_create();*/
+   dec = hybrid_decoder_create();
 
    in = (short*)malloc(frame_size*channels*sizeof(short));
    out = (short*)malloc(frame_size*channels*sizeof(short));
@@ -109,14 +110,14 @@ int main(int argc, char *argv[])
          return 1;
       }
       /* This is for simulating bit errors */
-      /*hybrid_decode(dec, data, len, out, frame_size);*/
+      hybrid_decode(dec, data, len, out, frame_size);
       count++;
       fwrite(out+skip, sizeof(short), (frame_size-skip)*channels, fout);
       skip = 0;
    }
 
    hybrid_encoder_destroy(enc);
-   /*hybrid_decoder_destroy(dec);*/
+   hybrid_decoder_destroy(dec);
    fclose(fin);
    fclose(fout);
    free(in);