1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-13 21:28:01 +02:00

Get rid of av_random in nellymoserdec.c

Originally committed as revision 18078 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
Benjamin Larsson 2009-03-20 21:15:02 +00:00
parent effcedf738
commit 3b0b84797e

View File

@ -32,7 +32,8 @@
*/ */
#include "nellymoser.h" #include "nellymoser.h"
#include "libavutil/random.h" #include "libavutil/lfg.h"
#include "libavutil/random_seed.h"
#include "avcodec.h" #include "avcodec.h"
#include "dsputil.h" #include "dsputil.h"
@ -44,7 +45,7 @@ typedef struct NellyMoserDecodeContext {
AVCodecContext* avctx; AVCodecContext* avctx;
DECLARE_ALIGNED_16(float,float_buf[NELLY_SAMPLES]); DECLARE_ALIGNED_16(float,float_buf[NELLY_SAMPLES]);
float state[128]; float state[128];
AVRandomState random_state; AVLFG random_state;
GetBitContext gb; GetBitContext gb;
int add_bias; int add_bias;
float scale_bias; float scale_bias;
@ -107,7 +108,7 @@ static void nelly_decode_block(NellyMoserDecodeContext *s,
for (j = 0; j < NELLY_FILL_LEN; j++) { for (j = 0; j < NELLY_FILL_LEN; j++) {
if (bits[j] <= 0) { if (bits[j] <= 0) {
aptr[j] = M_SQRT1_2*pows[j]; aptr[j] = M_SQRT1_2*pows[j];
if (av_random(&s->random_state) & 1) if (av_lfg_get(&s->random_state) & 1)
aptr[j] *= -1.0; aptr[j] *= -1.0;
} else { } else {
v = get_bits(&s->gb, bits[j]); v = get_bits(&s->gb, bits[j]);
@ -128,7 +129,7 @@ static av_cold int decode_init(AVCodecContext * avctx) {
NellyMoserDecodeContext *s = avctx->priv_data; NellyMoserDecodeContext *s = avctx->priv_data;
s->avctx = avctx; s->avctx = avctx;
av_random_init(&s->random_state, 0); av_lfg_init(&s->random_state, ff_random_get_seed());
ff_mdct_init(&s->imdct_ctx, 8, 1); ff_mdct_init(&s->imdct_ctx, 8, 1);
dsputil_init(&s->dsp, avctx); dsputil_init(&s->dsp, avctx);