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;
+}