From a5737c25ee7a00b75ba58fb78c27b37fbc14cc4f Mon Sep 17 00:00:00 2001 From: atmos4 Date: Sun, 16 Jun 2002 01:44:33 +0000 Subject: [PATCH] Fixed lround replacement, hopefully fast enough. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@6440 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libao2/pl_eq.c | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/libao2/pl_eq.c b/libao2/pl_eq.c index 2588b383d1..eb9234a297 100644 --- a/libao2/pl_eq.c +++ b/libao2/pl_eq.c @@ -89,16 +89,21 @@ static int control(int cmd,int arg){ return CONTROL_UNKNOWN; } +// return rounded 16bit int +static inline int16_t lround16(double n){ + return (int16_t)((n)>=0.0?(n)+0.5:(n)-0.5); +} + // 2nd order Band-pass Filter design void bp2(int16_t* a, int16_t* b, float fc, float q){ double th=2*3.141592654*fc; double C=(1 - tan(th*q/2))/(1 + tan(th*q/2)); - a[0] = (int16_t)( 16383.0 * (1 + C) * cos(th) + 0.5); - a[1] = (int16_t)(-16383.0 * C + 0.5); + a[0] = lround16( 16383.0 * (1 + C) * cos(th)); + a[1] = lround16(-16383.0 * C); - b[0] = (int16_t)(-16383.0 * (C - 1)/2 + 0.5); - b[1] = (int16_t)(-16383.0 * 1.0050 + 0.5); + b[0] = lround16(-16383.0 * (C - 1)/2); + b[1] = lround16(-16383.0 * 1.0050); } // empty buffers