FreeCalypso > hg > gsm-codec-lib
diff libgsmfr2/prng.c @ 256:a33edf624061
libgsmfr2: start with API definition and port of libgsmfrp code
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 12 Apr 2024 20:49:53 +0000 |
parents | libgsmfrp/prng.c@3b64f255689a |
children | 573afa985df6 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libgsmfr2/prng.c Fri Apr 12 20:49:53 2024 +0000 @@ -0,0 +1,53 @@ +/* + * We use a pseudorandom sequence generator function in two places: + * when generating comfort noise (GSM 06.12 section 6.1), and when + * randomizing grid position parameters as part of speech muting + * during error handling (GSM 06.11 section 6). + * + * Our PRNG is a copy of the pseudonoise() function from ETSI EFR code, + * where it is used for similar purposes. + */ + +#include <stdint.h> +#include "tw_gsmfr.h" +#include "pp_internal.h" + +uint16_t gsmfr_preproc_prng(struct gsmfr_preproc_state *st, uint16_t no_bits) +{ + uint16_t noise_bits, Sn, i; + + noise_bits = 0; + for (i = 0; i < no_bits; i++) + { + /* State n == 31 */ + if ((st->cn_random_lfsr & 0x00000001L) != 0) + { + Sn = 1; + } + else + { + Sn = 0; + } + + /* State n == 3 */ + if ((st->cn_random_lfsr & 0x10000000L) != 0) + { + Sn = Sn ^ 1; + } + else + { + Sn = Sn ^ 0; + } + + noise_bits = noise_bits << 1; + noise_bits = noise_bits | st->cn_random_lfsr & 1; + + st->cn_random_lfsr >>= 1; + if (Sn & 1) + { + st->cn_random_lfsr |= 0x40000000L; + } + } + + return noise_bits; +}