mirror of https://github.com/FFmpeg/FFmpeg.git
* commit '85990140e7302d1e7fcc9fc0eea316178c19fe03': dca: Add math helpers. Merged-by: Hendrik Leppkes <h.leppkes@gmail.com>pull/172/head
commit
a51c2fcdc1
1 changed files with 42 additions and 0 deletions
@ -0,0 +1,42 @@ |
||||
/*
|
||||
* This file is part of FFmpeg. |
||||
* |
||||
* FFmpeg is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU Lesser General Public |
||||
* License as published by the Free Software Foundation; either |
||||
* version 2.1 of the License, or (at your option) any later version. |
||||
* |
||||
* FFmpeg is distributed in the hope that it will be useful, |
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
||||
* Lesser General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Lesser General Public |
||||
* License along with FFmpeg; if not, write to the Free Software |
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
*/ |
||||
|
||||
#include "libavutil/common.h" |
||||
|
||||
|
||||
// clip a signed integer into the (-2^23), (2^23-1) range
|
||||
static inline int dca_clip23(int a) |
||||
{ |
||||
return av_clip_intp2(a, 23); |
||||
} |
||||
|
||||
static inline int32_t dca_norm(int64_t a, int bits) |
||||
{ |
||||
if (bits > 0) |
||||
return (int32_t)((a + (INT64_C(1) << (bits - 1))) >> bits); |
||||
else |
||||
return (int32_t)a; |
||||
} |
||||
|
||||
static inline int64_t dca_round(int64_t a, int bits) |
||||
{ |
||||
if (bits > 0) |
||||
return (a + (INT64_C(1) << (bits - 1))) & ~((INT64_C(1) << bits) - 1); |
||||
else |
||||
return a; |
||||
} |
Loading…
Reference in new issue