[FFmpeg-devel] [PATCH] lavc/aacenc: use isfinite to simplify isnan/isinf logic
Claudio Freire
klaussfreire at gmail.com
Fri Jan 15 00:14:34 CET 2016
On Thu, Jan 14, 2016 at 7:57 PM, Ganesh Ajjanagadde
<gajjanagadde at gmail.com> wrote:
> Signed-off-by: Ganesh Ajjanagadde <gajjanagadde at gmail.com>
> ---
> libavcodec/aacenc.c | 17 +++++++++--------
> 1 file changed, 9 insertions(+), 8 deletions(-)
>
> diff --git a/libavcodec/aacenc.c b/libavcodec/aacenc.c
> index 9a7d3a8..2e0db7d 100644
> --- a/libavcodec/aacenc.c
> +++ b/libavcodec/aacenc.c
> @@ -29,6 +29,7 @@
> * add sane pulse detection
> ***********************************/
>
> +#include "libavutil/libm.h"
> #include "libavutil/thread.h"
> #include "libavutil/float_dsp.h"
> #include "libavutil/opt.h"
> @@ -606,14 +607,14 @@ static int aac_encode_frame(AVCodecContext *avctx, AVPacket *avpkt,
> s->mdct1024.mdct_calc(&s->mdct1024, sce->lcoeffs, sce->ret_buf);
> }
>
> - if (isnan(cpe->ch->coeffs[ 0]) || isinf(cpe->ch->coeffs[ 0]) ||
> - isnan(cpe->ch->coeffs[ 128]) || isinf(cpe->ch->coeffs[ 128]) ||
> - isnan(cpe->ch->coeffs[2*128]) || isinf(cpe->ch->coeffs[2*128]) ||
> - isnan(cpe->ch->coeffs[3*128]) || isinf(cpe->ch->coeffs[3*128]) ||
> - isnan(cpe->ch->coeffs[4*128]) || isinf(cpe->ch->coeffs[4*128]) ||
> - isnan(cpe->ch->coeffs[5*128]) || isinf(cpe->ch->coeffs[5*128]) ||
> - isnan(cpe->ch->coeffs[6*128]) || isinf(cpe->ch->coeffs[6*128]) ||
> - isnan(cpe->ch->coeffs[7*128]) || isinf(cpe->ch->coeffs[7*128])
> + if (!(isfinite(cpe->ch->coeffs[ 0]) &&
> + isfinite(cpe->ch->coeffs[ 128]) &&
> + isfinite(cpe->ch->coeffs[2*128]) &&
> + isfinite(cpe->ch->coeffs[3*128]) &&
> + isfinite(cpe->ch->coeffs[4*128]) &&
> + isfinite(cpe->ch->coeffs[5*128]) &&
> + isfinite(cpe->ch->coeffs[6*128]) &&
> + isfinite(cpe->ch->coeffs[7*128]))
> ) {
> av_log(avctx, AV_LOG_ERROR, "Input contains NaN/+-Inf\n");
> return AVERROR(EINVAL);
lgtm
More information about the ffmpeg-devel
mailing list