From patchwork Mon Aug 22 21:02:04 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jai Luthra X-Patchwork-Id: 236 Delivered-To: ffmpegpatchwork@gmail.com Received: by 10.103.140.134 with SMTP id o128csp1948744vsd; Mon, 22 Aug 2016 14:02:36 -0700 (PDT) X-Received: by 10.194.236.68 with SMTP id us4mr18207589wjc.12.1471899755338; Mon, 22 Aug 2016 14:02:35 -0700 (PDT) Return-Path: Received: from ffbox0-bg.mplayerhq.hu (ffbox0-bg.ffmpeg.org. [79.124.17.100]) by mx.google.com with ESMTP id 128si17881880wmq.81.2016.08.22.14.02.29; Mon, 22 Aug 2016 14:02:35 -0700 (PDT) Received-SPF: pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) client-ip=79.124.17.100; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@jailuthra-in.20150623.gappssmtp.com; spf=pass (google.com: domain of ffmpeg-devel-bounces@ffmpeg.org designates 79.124.17.100 as permitted sender) smtp.mailfrom=ffmpeg-devel-bounces@ffmpeg.org Received: from [127.0.1.1] (localhost [127.0.0.1]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTP id 6D246689B53; Tue, 23 Aug 2016 00:02:22 +0300 (EEST) X-Original-To: ffmpeg-devel@ffmpeg.org Delivered-To: ffmpeg-devel@ffmpeg.org Received: from mail-pf0-f193.google.com (mail-pf0-f193.google.com [209.85.192.193]) by ffbox0-bg.mplayerhq.hu (Postfix) with ESMTPS id 36105689AF6 for ; Tue, 23 Aug 2016 00:02:10 +0300 (EEST) Received: by mail-pf0-f193.google.com with SMTP id g202so6951370pfb.1 for ; Mon, 22 Aug 2016 14:02:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=jailuthra-in.20150623.gappssmtp.com; s=20150623; h=date:from:to:subject:message-id:mime-version:content-disposition :user-agent; bh=aIY70gqNoLELbe6YRUiqkxj+IX8CE/pgb6BD4fFdZTY=; b=Fn/zD40d3Ez3vb3D38D9UBrnuoFPFvCUTc2OimLI+P+nyIF/Q0uUBSXHx330+Gbggp ahwrydCe7znm5uZjdNNACu+iUbPVu0rWNvDyjgssSSl1vyHZjTZNjf62n+MA7m2sOfkv q/KL6WTXC5mcSc2LUf2u0L70oJl1vsKwjKRAZoxcqDTubMO8OCda8cPUGIdl9lysGMv3 d1PTqN+VoHVtsXY+FsvG7y0N3RYho4DU61smMwhOkIS9Kq6Qj7usTXH8kHJeCPYlObin LGlAvL3Ur1WU1NirF6U7lAKmxQ7+z7zrx7benL+GM7aWkuDPzYBf/L6IsEKEco0m4DVu Y0TA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:date:from:to:subject:message-id:mime-version :content-disposition:user-agent; bh=aIY70gqNoLELbe6YRUiqkxj+IX8CE/pgb6BD4fFdZTY=; b=j+BVLetSzenbfeqx/Ad5/OntMlx8wes5g1ZJgtlPGsOcd/N2UwjVaRxbqrC0Py1xCA BVp+A3xCDTNwtAF+CC8YucfD6PxG1p9BAHHoAiYzTMwjqko2fnCg77S0r/qDlAauzqB5 v/15cMFOhox9TMRswVzX24gUKLUnN76y5+oCXpOBTkpOHYgkW5pjKCqweMGlVzjfHWRi yx7iyOVM7aeArsy3w3ibD8dCpERKidapd4nNLQYECN7fDfTt66hFOC1RChpMH/Jfdeh+ D+pJ462PrHcqrp1XyiC7yKL2a7nmurIxymxPt+pH11JSaiU+bVIuhxUVVhkvlYzIQ8cN jqJA== X-Gm-Message-State: AEkoouvV64pU9eNRfqyIjNzaVTUXfnOHO4zbzwlCKWgE0/Sld297EASC8oc2QOrBDY5org== X-Received: by 10.98.72.28 with SMTP id v28mr46494350pfa.139.1471899730320; Mon, 22 Aug 2016 14:02:10 -0700 (PDT) Received: from mayhem.iiitd.edu.in ([103.25.231.2]) by smtp.googlemail.com with ESMTPSA id 6sm34341592pab.11.2016.08.22.14.02.08 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 22 Aug 2016 14:02:09 -0700 (PDT) Date: Tue, 23 Aug 2016 02:32:04 +0530 From: Jai Luthra To: ffmpeg-devel@ffmpeg.org Message-ID: <20160822210204.GA23717@mayhem.iiitd.edu.in> MIME-Version: 1.0 Content-Disposition: inline X-PGP-Key: http://jailuthra.in/files/public-key.asc User-Agent: Mutt/1.5.24 (2015-08-30) Subject: [FFmpeg-devel] [GSoC] [PATCH 1/2] lavc/lpc: Add min_shift parameter in LPC X-BeenThere: ffmpeg-devel@ffmpeg.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: FFmpeg development discussions and patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Reply-To: FFmpeg development discussions and patches Errors-To: ffmpeg-devel-bounces@ffmpeg.org Sender: "ffmpeg-devel" The min_shift parameter is needed by the MLP encoder Signed-off-by: Jai Luthra --- libavcodec/alacenc.c | 4 +++- libavcodec/flacenc.c | 3 ++- libavcodec/lpc.c | 13 ++++++++----- libavcodec/lpc.h | 2 +- libavcodec/ra144enc.c | 2 +- 5 files changed, 15 insertions(+), 9 deletions(-) diff --git a/libavcodec/alacenc.c b/libavcodec/alacenc.c index 9ac35f1..6a887ff 100644 --- a/libavcodec/alacenc.c +++ b/libavcodec/alacenc.c @@ -38,6 +38,7 @@ #define DEFAULT_MAX_PRED_ORDER 6 #define DEFAULT_MIN_PRED_ORDER 4 #define ALAC_MAX_LPC_PRECISION 9 +#define ALAC_MIN_LPC_SHIFT 0 #define ALAC_MAX_LPC_SHIFT 9 #define ALAC_CHMODE_LEFT_RIGHT 0 @@ -171,7 +172,8 @@ static void calc_predictor_params(AlacEncodeContext *s, int ch) s->max_prediction_order, ALAC_MAX_LPC_PRECISION, coefs, shift, FF_LPC_TYPE_LEVINSON, 0, - ORDER_METHOD_EST, ALAC_MAX_LPC_SHIFT, 1); + ORDER_METHOD_EST, ALAC_MIN_LPC_SHIFT, + ALAC_MAX_LPC_SHIFT, 1); s->lpc[ch].lpc_order = opt_order; s->lpc[ch].lpc_quant = shift[opt_order-1]; diff --git a/libavcodec/flacenc.c b/libavcodec/flacenc.c index 9d6a742..3575f53 100644 --- a/libavcodec/flacenc.c +++ b/libavcodec/flacenc.c @@ -44,6 +44,7 @@ #define MAX_PARTITION_ORDER 8 #define MAX_PARTITIONS (1 << MAX_PARTITION_ORDER) #define MAX_LPC_PRECISION 15 +#define MIN_LPC_SHIFT 0 #define MAX_LPC_SHIFT 15 enum CodingMode { @@ -884,7 +885,7 @@ static int encode_residual_ch(FlacEncodeContext *s, int ch) opt_order = ff_lpc_calc_coefs(&s->lpc_ctx, smp, n, min_order, max_order, s->options.lpc_coeff_precision, coefs, shift, s->options.lpc_type, s->options.lpc_passes, omethod, - MAX_LPC_SHIFT, 0); + MIN_LPC_SHIFT, MAX_LPC_SHIFT, 0); if (omethod == ORDER_METHOD_2LEVEL || omethod == ORDER_METHOD_4LEVEL || diff --git a/libavcodec/lpc.c b/libavcodec/lpc.c index 052aeaa..f8da1e1 100644 --- a/libavcodec/lpc.c +++ b/libavcodec/lpc.c @@ -93,7 +93,8 @@ static void lpc_compute_autocorr_c(const double *data, int len, int lag, * Quantize LPC coefficients */ static void quantize_lpc_coefs(double *lpc_in, int order, int precision, - int32_t *lpc_out, int *shift, int max_shift, int zero_shift) + int32_t *lpc_out, int *shift, int min_shift, + int max_shift, int zero_shift) { int i; double cmax, error; @@ -118,7 +119,7 @@ static void quantize_lpc_coefs(double *lpc_in, int order, int precision, /* calculate level shift which scales max coeff to available bits */ sh = max_shift; - while((cmax * (1 << sh) > qmax) && (sh > 0)) { + while((cmax * (1 << sh) > qmax) && (sh > min_shift)) { sh--; } @@ -201,7 +202,7 @@ int ff_lpc_calc_coefs(LPCContext *s, int max_order, int precision, int32_t coefs[][MAX_LPC_ORDER], int *shift, enum FFLPCType lpc_type, int lpc_passes, - int omethod, int max_shift, int zero_shift) + int omethod, int min_shift, int max_shift, int zero_shift) { double autoc[MAX_LPC_ORDER+1]; double ref[MAX_LPC_ORDER] = { 0 }; @@ -284,10 +285,12 @@ int ff_lpc_calc_coefs(LPCContext *s, if(omethod == ORDER_METHOD_EST) { opt_order = estimate_best_order(ref, min_order, max_order); i = opt_order-1; - quantize_lpc_coefs(lpc[i], i+1, precision, coefs[i], &shift[i], max_shift, zero_shift); + quantize_lpc_coefs(lpc[i], i+1, precision, coefs[i], &shift[i], + min_shift, max_shift, zero_shift); } else { for(i=min_order-1; ilpc_ctx, lpc_data, NBLOCKS * BLOCKSIZE, LPC_ORDER, LPC_ORDER, 16, lpc_coefs, shift, FF_LPC_TYPE_LEVINSON, - 0, ORDER_METHOD_EST, 12, 0); + 0, ORDER_METHOD_EST, 0, 12, 0); for (i = 0; i < LPC_ORDER; i++) block_coefs[NBLOCKS - 1][i] = -(lpc_coefs[LPC_ORDER - 1][i] << (12 - shift[LPC_ORDER - 1]));