| /* |
| * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| /* |
| * entropy_coding.h |
| * |
| * This header file contains all of the functions used to arithmetically |
| * encode the iSAC bistream |
| * |
| */ |
| |
| #ifndef MODULES_AUDIO_CODING_CODECS_ISAC_FIX_SOURCE_ENTROPY_CODING_H_ |
| #define MODULES_AUDIO_CODING_CODECS_ISAC_FIX_SOURCE_ENTROPY_CODING_H_ |
| |
| #include "modules/audio_coding/codecs/isac/fix/source/structs.h" |
| |
| /* decode complex spectrum (return number of bytes in stream) */ |
| int WebRtcIsacfix_DecodeSpec(Bitstr_dec* streamdata, |
| int16_t* frQ7, |
| int16_t* fiQ7, |
| int16_t AvgPitchGain_Q12); |
| |
| /* encode complex spectrum */ |
| int WebRtcIsacfix_EncodeSpec(const int16_t* fr, |
| const int16_t* fi, |
| Bitstr_enc* streamdata, |
| int16_t AvgPitchGain_Q12); |
| |
| /* decode & dequantize LPC Coef */ |
| int WebRtcIsacfix_DecodeLpcCoef(Bitstr_dec* streamdata, |
| int32_t* LPCCoefQ17, |
| int32_t* gain_lo_hiQ17, |
| int16_t* outmodel); |
| |
| int WebRtcIsacfix_DecodeLpc(int32_t* gain_lo_hiQ17, |
| int16_t* LPCCoef_loQ15, |
| int16_t* LPCCoef_hiQ15, |
| Bitstr_dec* streamdata, |
| int16_t* outmodel); |
| |
| /* quantize & code LPC Coef */ |
| int WebRtcIsacfix_EncodeLpc(int32_t* gain_lo_hiQ17, |
| int16_t* LPCCoef_loQ15, |
| int16_t* LPCCoef_hiQ15, |
| int16_t* model, |
| int32_t* sizeQ11, |
| Bitstr_enc* streamdata, |
| IsacSaveEncoderData* encData, |
| transcode_obj* transcodeParam); |
| |
| int WebRtcIsacfix_EstCodeLpcGain(int32_t* gain_lo_hiQ17, |
| Bitstr_enc* streamdata, |
| IsacSaveEncoderData* encData); |
| /* decode & dequantize RC */ |
| int WebRtcIsacfix_DecodeRcCoef(Bitstr_dec* streamdata, int16_t* RCQ15); |
| |
| /* quantize & code RC */ |
| int WebRtcIsacfix_EncodeRcCoef(int16_t* RCQ15, Bitstr_enc* streamdata); |
| |
| /* decode & dequantize squared Gain */ |
| int WebRtcIsacfix_DecodeGain2(Bitstr_dec* streamdata, int32_t* Gain2); |
| |
| /* quantize & code squared Gain (input is squared gain) */ |
| int WebRtcIsacfix_EncodeGain2(int32_t* gain2, Bitstr_enc* streamdata); |
| |
| int WebRtcIsacfix_EncodePitchGain(int16_t* PitchGains_Q12, |
| Bitstr_enc* streamdata, |
| IsacSaveEncoderData* encData); |
| |
| int WebRtcIsacfix_EncodePitchLag(int16_t* PitchLagQ7, |
| int16_t* PitchGain_Q12, |
| Bitstr_enc* streamdata, |
| IsacSaveEncoderData* encData); |
| |
| int WebRtcIsacfix_DecodePitchGain(Bitstr_dec* streamdata, |
| int16_t* PitchGain_Q12); |
| |
| int WebRtcIsacfix_DecodePitchLag(Bitstr_dec* streamdata, |
| int16_t* PitchGain_Q12, |
| int16_t* PitchLagQ7); |
| |
| int WebRtcIsacfix_DecodeFrameLen(Bitstr_dec* streamdata, size_t* framelength); |
| |
| int WebRtcIsacfix_EncodeFrameLen(int16_t framelength, Bitstr_enc* streamdata); |
| |
| int WebRtcIsacfix_DecodeSendBandwidth(Bitstr_dec* streamdata, int16_t* BWno); |
| |
| int WebRtcIsacfix_EncodeReceiveBandwidth(int16_t* BWno, Bitstr_enc* streamdata); |
| |
| void WebRtcIsacfix_TranscodeLpcCoef(int32_t* tmpcoeffs_gQ6, int16_t* index_gQQ); |
| |
| // Pointer functions for LPC transforms. |
| |
| typedef void (*MatrixProduct1)(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix1_index_factor1, |
| const int matrix0_index_factor1, |
| const int matrix1_index_init_case, |
| const int matrix1_index_step, |
| const int matrix0_index_step, |
| const int inner_loop_count, |
| const int mid_loop_count, |
| const int shift); |
| typedef void (*MatrixProduct2)(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix0_index_factor, |
| const int matrix0_index_step); |
| |
| extern MatrixProduct1 WebRtcIsacfix_MatrixProduct1; |
| extern MatrixProduct2 WebRtcIsacfix_MatrixProduct2; |
| |
| void WebRtcIsacfix_MatrixProduct1C(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix1_index_factor1, |
| const int matrix0_index_factor1, |
| const int matrix1_index_init_case, |
| const int matrix1_index_step, |
| const int matrix0_index_step, |
| const int inner_loop_count, |
| const int mid_loop_count, |
| const int shift); |
| void WebRtcIsacfix_MatrixProduct2C(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix0_index_factor, |
| const int matrix0_index_step); |
| |
| #if defined(WEBRTC_HAS_NEON) |
| void WebRtcIsacfix_MatrixProduct1Neon(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix1_index_factor1, |
| const int matrix0_index_factor1, |
| const int matrix1_index_init_case, |
| const int matrix1_index_step, |
| const int matrix0_index_step, |
| const int inner_loop_count, |
| const int mid_loop_count, |
| const int shift); |
| void WebRtcIsacfix_MatrixProduct2Neon(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix0_index_factor, |
| const int matrix0_index_step); |
| #endif |
| |
| #if defined(MIPS32_LE) |
| void WebRtcIsacfix_MatrixProduct1MIPS(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix1_index_factor1, |
| const int matrix0_index_factor1, |
| const int matrix1_index_init_case, |
| const int matrix1_index_step, |
| const int matrix0_index_step, |
| const int inner_loop_count, |
| const int mid_loop_count, |
| const int shift); |
| |
| void WebRtcIsacfix_MatrixProduct2MIPS(const int16_t matrix0[], |
| const int32_t matrix1[], |
| int32_t matrix_product[], |
| const int matrix0_index_factor, |
| const int matrix0_index_step); |
| #endif |
| |
| #endif // MODULES_AUDIO_CODING_CODECS_ISAC_FIX_SOURCE_ENTROPY_CODING_H_ |