ref: 04584eac3178e3f68dc5f0b07cfc4a1ec3cd2406
parent: 8bb076bbf3c9e564b0a6d343f0e975ddbb3785c7
author: Jean-Marc Valin <[email protected]>
date: Wed Jun 30 11:03:35 EDT 2010
Decoder structure
--- a/src/hybrid.h
+++ b/src/hybrid.h
@@ -30,10 +30,19 @@
*/
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);
+
--- /dev/null
+++ b/src/hybrid_decoder.c
@@ -1,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);
+}
--- /dev/null
+++ b/src/hybrid_decoder.h
@@ -1,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 */
+
--- a/src/hybrid_encoder.c
+++ b/src/hybrid_encoder.c
@@ -55,7 +55,7 @@
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;
--- a/src/test_hybrid.c
+++ b/src/test_hybrid.c
@@ -49,6 +49,7 @@
char *inFile, *outFile;
FILE *fin, *fout;
HybridEncoder *enc;
+ HybridDecoder *dec;
int len;
int frame_size, channels;
int bytes_per_packet;
@@ -93,7 +94,7 @@
}
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,7 +110,7 @@
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;
@@ -116,7 +117,7 @@
}
hybrid_encoder_destroy(enc);
- /*hybrid_decoder_destroy(dec);*/
+ hybrid_decoder_destroy(dec);
fclose(fin);
fclose(fout);
free(in);