changeset 381:32bc48faec4b

libtwamr: integrate int_lpc.c
author Mychaela Falconia <falcon@freecalypso.org>
date Mon, 06 May 2024 05:35:21 +0000
parents 2ed325c9a507
children 693ea1d5cf1e
files libtwamr/Makefile libtwamr/int_lpc.c libtwamr/int_lpc.h libtwamr/namespace.list
diffstat 4 files changed, 395 insertions(+), 5 deletions(-) [+]
line wrap: on
line diff
--- a/libtwamr/Makefile	Mon May 06 05:31:47 2024 +0000
+++ b/libtwamr/Makefile	Mon May 06 05:35:21 2024 +0000
@@ -7,11 +7,11 @@
 	d_gain_p.o d_plsf.o d_plsf_3.o d_plsf_5.o dec_gain.o dec_lag3.o \
 	dec_lag6.o dhf_check.o dhf_tables.o e_homing.o ec_gains.o enc_lag3.o \
 	enc_lag6.o ex_ctrl.o g_adapt.o g_code.o g_pitch.o gain_q.o gains_tab.o \
-	gc_pred.o gmed_n.o graytab.o hp_max.o inv_sqrt.o log2.o lsfwt.o \
-	lsp_az.o lsp_lsf.o mac_32.o oper_32b.o pow2.o prmno.o q_gain_c.o \
-	q_gain_p.o q_plsf.o q_plsf3_tab.o q_plsf5_tab.o q_plsf_3.o q_plsf_5.o \
-	qgain475.o qgain795.o qua_gain.o qua_gain_tab.o reorder.o s10_8pf.o \
-	set_sign.o sqrt_l.o tls_flags.o window.o
+	gc_pred.o gmed_n.o graytab.o hp_max.o int_lpc.o inv_sqrt.o log2.o \
+	lsfwt.o lsp_az.o lsp_lsf.o mac_32.o oper_32b.o pow2.o prmno.o \
+	q_gain_c.o q_gain_p.o q_plsf.o q_plsf3_tab.o q_plsf5_tab.o q_plsf_3.o \
+	q_plsf_5.o qgain475.o qgain795.o qua_gain.o qua_gain_tab.o reorder.o \
+	s10_8pf.o set_sign.o sqrt_l.o tls_flags.o window.o
 HDRS=	namespace.h
 LIB=	libtwamr.a
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libtwamr/int_lpc.c	Mon May 06 05:35:21 2024 +0000
@@ -0,0 +1,256 @@
+/*
+********************************************************************************
+*
+*      GSM AMR-NB speech codec   R98   Version 7.6.0   December 12, 2001
+*                                R99   Version 3.3.0                
+*                                REL-4 Version 4.1.0                
+*
+********************************************************************************
+*
+*      File             : int_lpc.c
+*
+********************************************************************************
+*/
+/*
+********************************************************************************
+*                         MODULE INCLUDE FILE AND VERSION ID
+********************************************************************************
+*/
+#include "namespace.h"
+#include "int_lpc.h"
+ 
+/*
+********************************************************************************
+*                         INCLUDE FILES
+********************************************************************************
+*/
+#include "typedef.h"
+#include "basic_op.h"
+#include "no_count.h"
+#include "cnst.h"
+#include "lsp_az.h" 
+
+/*
+********************************************************************************
+*                         LOCAL VARIABLES AND TABLES
+********************************************************************************
+*/
+/*
+*--------------------------------------*
+* Constants (defined in cnst.h)        *
+*--------------------------------------*
+*  M         : LPC order               *
+*  MP1       : LPC order + 1           *
+*--------------------------------------*
+*/
+ 
+/*
+********************************************************************************
+*                         PUBLIC PROGRAM CODE
+********************************************************************************
+*/
+/*
+**************************************************************************
+*
+*  Function    : Int_lpc_1and3
+*  Purpose     : Interpolates the LSPs and converts to LPC parameters 
+*                to get a different LP filter in each subframe.
+*  Description : The 20 ms speech frame is divided into 4 subframes.
+*                The LSPs are quantized and transmitted at the 2nd and 
+*                4th subframes (twice per frame) and interpolated at the
+*                1st and 3rd subframe.
+*
+*                      |------|------|------|------|
+*                         sf1    sf2    sf3    sf4
+*                   F0            Fm            F1
+*      
+*                 sf1:   1/2 Fm + 1/2 F0         sf3:   1/2 F1 + 1/2 Fm
+*                 sf2:       Fm                  sf4:       F1
+*  Returns     : void
+*
+**************************************************************************
+*/
+void Int_lpc_1and3 (
+    Word16 lsp_old[],  /* i : LSP vector at the 4th subfr. of past frame (M) */
+    Word16 lsp_mid[],  /* i : LSP vector at the 2nd subfr. of
+                              present frame (M)                              */
+    Word16 lsp_new[],  /* i : LSP vector at the 4th subfr. of
+                              present frame (M)                              */
+    Word16 Az[]        /* o : interpolated LP parameters in all subfr.
+                              (AZ_SIZE)                                      */
+)
+{
+    Word16 i;
+    Word16 lsp[M];
+
+    /*  lsp[i] = lsp_mid[i] * 0.5 + lsp_old[i] * 0.5 */
+
+    for (i = 0; i < M; i++)
+    {
+        lsp[i] = add (shr (lsp_mid[i], 1), shr (lsp_old[i], 1));
+                                move16 (); 
+    }
+
+    Lsp_Az (lsp, Az);           /* Subframe 1 */
+    Az += MP1;                  move16 (); 
+
+    Lsp_Az (lsp_mid, Az);       /* Subframe 2 */
+    Az += MP1;                  move16 (); 
+
+    for (i = 0; i < M; i++)
+    {
+        lsp[i] = add (shr (lsp_mid[i], 1), shr (lsp_new[i], 1));
+                                move16 (); 
+    }
+
+    Lsp_Az (lsp, Az);           /* Subframe 3 */
+    Az += MP1;                  move16 (); 
+
+    Lsp_Az (lsp_new, Az);       /* Subframe 4 */
+
+    return;
+}
+
+/*
+**************************************************************************
+*
+*  Function    : Int_lpc_1and3_2
+*  Purpose     : Interpolation of the LPC parameters. Same as the Int_lpc
+*                function but we do not recompute Az() for subframe 2 and
+*                4 because it is already available.
+*  Returns     : void
+*
+**************************************************************************
+*/
+void Int_lpc_1and3_2 (
+    Word16 lsp_old[],  /* i : LSP vector at the 4th subfr. of past frame (M) */
+    Word16 lsp_mid[],  /* i : LSP vector at the 2nd subframe of
+                             present frame (M)                                  */
+    Word16 lsp_new[],  /* i : LSP vector at the 4th subframe of
+                             present frame (M)                                  */
+    Word16 Az[]        /* o :interpolated LP parameters
+                             in subframes 1 and 3 (AZ_SIZE)                     */
+)
+{
+    Word16 i;
+    Word16 lsp[M];
+
+    /*  lsp[i] = lsp_mid[i] * 0.5 + lsp_old[i] * 0.5 */
+
+    for (i = 0; i < M; i++)
+    {
+        lsp[i] = add (shr (lsp_mid[i], 1), shr (lsp_old[i], 1));
+                                move16 (); 
+    }
+    Lsp_Az (lsp, Az);           /* Subframe 1 */
+    Az += MP1 * 2;              move16 (); 
+
+    for (i = 0; i < M; i++)
+    {
+        lsp[i] = add (shr (lsp_mid[i], 1), shr (lsp_new[i], 1));
+                                move16 (); 
+    }
+    Lsp_Az (lsp, Az);           /* Subframe 3 */
+
+    return;
+}
+/*************************************************************************
+ *
+ *  FUNCTION:  Int_lpc_1to3()
+ *
+ *  PURPOSE:  Interpolates the LSPs and convert to LP parameters to get
+ *            a different LP filter in each subframe.
+ *
+ *  DESCRIPTION:
+ *     The 20 ms speech frame is divided into 4 subframes.
+ *     The LSPs are quantized and transmitted at the 4th subframe
+ *     (once per frame) and interpolated at the 1st, 2nd and 3rd subframe.
+ *
+ *          |------|------|------|------|
+ *             sf1    sf2    sf3    sf4
+ *       F0                          F1
+ *
+ *     sf1:   3/4 F0 + 1/4 F1         sf3:   1/4 F0 + 3/4 F1
+ *     sf2:   1/2 F0 + 1/2 F1         sf4:       F1
+ *
+ *************************************************************************/
+void Int_lpc_1to3(
+    Word16 lsp_old[], /* input : LSP vector at the 4th SF of past frame    */
+    Word16 lsp_new[], /* input : LSP vector at the 4th SF of present frame */
+    Word16 Az[]       /* output: interpolated LP parameters in all SFs     */
+)
+{
+    Word16 i;
+    Word16 lsp[M];
+
+    for (i = 0; i < M; i++) {
+        lsp[i] = add(shr(lsp_new[i], 2), sub(lsp_old[i], shr(lsp_old[i], 2)));
+		                    move16 ();
+    }
+
+    Lsp_Az(lsp, Az);        /* Subframe 1 */
+    Az += MP1;              move16 (); 
+
+
+    for (i = 0; i < M; i++) {
+        lsp[i] = add(shr(lsp_old[i], 1), shr(lsp_new[i], 1));
+		                    move16 ();
+    }
+
+    Lsp_Az(lsp, Az);        /* Subframe 2 */
+    Az += MP1;              move16 ();
+
+    for (i = 0; i < M; i++) {
+        lsp[i] = add(shr(lsp_old[i], 2), sub(lsp_new[i], shr(lsp_new[i], 2)));
+		                    move16 ();
+    }
+
+    Lsp_Az(lsp, Az);       /* Subframe 3 */
+    Az += MP1;              move16 ();
+
+    Lsp_Az(lsp_new, Az);        /* Subframe 4 */
+
+    return;
+}
+
+/*************************************************************************
+ * Function Int_lpc_1to3_2()
+ * Interpolation of the LPC parameters.
+ * Same as the previous function but we do not recompute Az() for
+ * subframe 4 because it is already available.
+ *************************************************************************/
+
+void Int_lpc_1to3_2(
+     Word16 lsp_old[],  /* input : LSP vector at the 4th SF of past frame    */
+     Word16 lsp_new[],  /* input : LSP vector at the 4th SF of present frame */
+     Word16 Az[]        /* output: interpolated LP parameters in SFs 1,2,3   */
+)
+{
+    Word16 i;
+    Word16 lsp[M];
+
+    for (i = 0; i < M; i++) {
+        lsp[i] = add(shr(lsp_new[i], 2), sub(lsp_old[i], shr(lsp_old[i], 2)));
+		                    move16 ();
+    }
+
+    Lsp_Az(lsp, Az);        /* Subframe 1 */
+    Az += MP1;              move16 ();
+
+    for (i = 0; i < M; i++) {
+        lsp[i] = add(shr(lsp_old[i], 1), shr(lsp_new[i], 1));
+		                    move16 ();
+    }
+
+    Lsp_Az(lsp, Az);        /* Subframe 2 */
+    Az += MP1;              move16 ();
+
+    for (i = 0; i < M; i++) {
+        lsp[i] = add(shr(lsp_old[i], 2), sub(lsp_new[i], shr(lsp_new[i], 2)));
+		                    move16 ();
+    }
+
+    Lsp_Az(lsp, Az);        /* Subframe 3 */
+
+    return;
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libtwamr/int_lpc.h	Mon May 06 05:35:21 2024 +0000
@@ -0,0 +1,133 @@
+/*
+********************************************************************************
+*
+*      GSM AMR-NB speech codec   R98   Version 7.6.0   December 12, 2001
+*                                R99   Version 3.3.0                
+*                                REL-4 Version 4.1.0                
+*
+********************************************************************************
+*
+*      File             : int_lpc.h
+*      Purpose          : Interpolates the LSPs and converts to LPC parameters 
+*
+********************************************************************************
+*/
+#ifndef int_lpc_h
+#define int_lpc_h "$Id $"
+ 
+/*
+********************************************************************************
+*                         INCLUDE FILES
+********************************************************************************
+*/
+#include "typedef.h"
+ 
+/*
+********************************************************************************
+*                         DEFINITION OF DATA TYPES
+********************************************************************************
+*/
+ 
+/*
+********************************************************************************
+*                         DECLARATION OF PROTOTYPES
+********************************************************************************
+*/
+/*
+**************************************************************************
+*
+*  Function    : Int_lpc_1and3
+*  Purpose     : Interpolates the LSPs and converts to LPC parameters 
+*                to get a different LP filter in each subframe.
+*  Description : The 20 ms speech frame is divided into 4 subframes.
+*                The LSPs are quantized and transmitted at the 2nd and 
+*                4th subframes (twice per frame) and interpolated at the
+*                1st and 3rd subframe.
+*
+*                      |------|------|------|------|
+*                         sf1    sf2    sf3    sf4
+*                   F0            Fm            F1
+*      
+*                 sf1:   1/2 Fm + 1/2 F0         sf3:   1/2 F1 + 1/2 Fm
+*                 sf2:       Fm                  sf4:       F1
+*  Returns     : void
+*
+**************************************************************************
+*/
+void Int_lpc_1and3 (
+    Word16 lsp_old[],  /* i : LSP vector at the 4th subfr. of past frame (M) */
+    Word16 lsp_mid[],  /* i : LSP vector at the 2nd subfr. of
+                              present frame (M)                              */
+    Word16 lsp_new[],  /* i : LSP vector at the 4th subfr. of
+                              present frame (M)                              */
+    Word16 Az[]        /* o : interpolated LP parameters in all subfr.
+                              (AZ_SIZE)                                      */
+);
+
+/*
+**************************************************************************
+*
+*  Function    : Int_lpc_1and3_2
+*  Purpose     : Interpolation of the LPC parameters. Same as the Int_lpc
+*                function but we do not recompute Az() for subframe 2 and
+*                4 because it is already available.
+*  Returns     : void
+*
+**************************************************************************
+*/
+void Int_lpc_1and3_2 (
+    Word16 lsp_old[],  /* i : LSP vector at the 4th subfr. of past frame (M) */
+    Word16 lsp_mid[],  /* i : LSP vector at the 2nd subframe of
+                             present frame (M)                                  */
+    Word16 lsp_new[],  /* i : LSP vector at the 4th subframe of
+                             present frame (M)                                  */
+    Word16 Az[]        /* o :interpolated LP parameters
+                             in subframes 1 and 3 (AZ_SIZE)                     */
+);
+
+/*
+**************************************************************************
+*
+*  Function    : Int_lpc_1to3
+*  Purpose     : Interpolates the LSPs and converts to LPC parameters 
+*                to get a different LP filter in each subframe.
+*  Description : The 20 ms speech frame is divided into 4 subframes.
+*                The LSPs are quantized and transmitted at the 4th 
+*                subframes (once per frame) and interpolated at the
+*                1st, 2nd and 3rd subframe.
+*
+*                      |------|------|------|------|
+*                         sf1    sf2    sf3    sf4
+*                   F0                          F1
+*      
+*                 sf1:   3/4 F0 + 1/4 F1         sf3:   1/4 F0 + 3/4 F1
+*                 sf2:   1/2 F0 + 1/2 F1         sf4:       F1
+*  Returns     : void
+*
+**************************************************************************
+*/
+void Int_lpc_1to3 (
+    Word16 lsp_old[], /* i : LSP vector at the 4th SF of past frame (M)      */
+    Word16 lsp_new[], /* i : LSP vector at the 4th SF of present frame (M)   */
+    Word16 Az[]       /* o : interpolated LP parameters in all SFs (AZ_SIZE) */
+);
+ 
+/*
+**************************************************************************
+*
+*  Function    : Int_lpc_1to3_2
+*  Purpose     : Interpolation of the LPC parameters. Same as the Int_lpc
+*                function but we do not recompute Az() for subframe 4
+*                because it is already available.
+*  Returns     : void
+*
+**************************************************************************
+*/
+void Int_lpc_1to3_2 (
+    Word16 lsp_old[],  /* i : LSP vector at the 4th SF of past frame (M) */
+    Word16 lsp_new[],  /* i : LSP vector at the 4th SF present frame (M) */
+    Word16 Az[]        /* o :interpolated LP parameters in SFs 1, 2, 3 
+                             (AZ_SIZE)                                   */
+);
+ 
+#endif
--- a/libtwamr/namespace.list	Mon May 06 05:31:47 2024 +0000
+++ b/libtwamr/namespace.list	Mon May 06 05:35:21 2024 +0000
@@ -23,6 +23,7 @@
 D_plsf_reset D_plsf_5 D_plsf_3 Init_D_plsf_3
 Enc_lag3 Enc_lag6 Ex_ctrl
 G_code G_pitch
+Int_lpc_1and3 Int_lpc_1and3_2 Int_lpc_1to3 Int_lpc_1to3_2
 Lsf_lsp Lsp_lsf Reorder_lsf Lsf_wt Lsp_Az
 Q_plsf_reset Q_plsf_3 Q_plsf_5 Qua_gain