diff intercom/gsm/rpeltp.c @ 2:13be24d74cd2

import intercom-0.4.1
author Peter Meerwald <pmeerw@cosy.sbg.ac.at>
date Fri, 25 Jun 2010 09:57:52 +0200 (2010-06-25)
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/intercom/gsm/rpeltp.c	Fri Jun 25 09:57:52 2010 +0200
@@ -0,0 +1,282 @@
+/*                                                          v1.0 - 12/Apr/1994
+  =============================================================================
+
+                          U    U   GGG    SSSS  TTTTT
+                          U    U  G       S       T
+                          U    U  G  GG   SSSS    T
+                          U    U  G   G       S   T
+                           UUU     GG     SSS     T
+
+                   ========================================
+                    ITU-T - USER'S GROUP ON SOFTWARE TOOLS
+                   ========================================
+
+MODULE:         RPELTP.C - GSM 06.10 RPE-LTP SPEECH ENCODING ALGORITHM
+
+ORIGINAL BY:
+
+ The driving routines of this module were written by:
+   Simao Ferraz de Campos Neto
+   DDS/Pr11                      Tel: +55-192-39-6637
+   CPqD/Telebras                 Fax: +55-192-39-6125
+   13088-061 Campinas SP Brazil  E-mail: <simao@cpqd.ansp.br>
+   
+ The true implementation was done by
+   Jutta Deneger (jutta@cs.tu-berlin.de)
+   Carsten Borman (cabo@cs.tu-berlin.de)
+   Communications and Operating Systems Research Group (KBS) 
+   Technishe Universitaet Berlin
+  
+ The portability changes on the code and rearrangement were done by <simao> 
+  
+DATE:           12/Apr/1994: 18H00 -3H00GMT
+
+RELEASE:        1.00
+
+PROTOTYPES:     see rpeltp.h for driving-routine prototypes, gsm.h for 
+		general prototypes, and private.h for special definitions.
+
+OBSERVATION:
+  Copyright note by the original authors:
+  " Copyright 1992 by Jutta Degener and Carsten Bormann, Technische
+    Universitaet Berlin.  See the accompanying file "COPYRIGHT" for
+    details.  THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE."
+
+FUNCTIONS: (Only UGST user-level functions!)
+
+rpeltp_init() ......... Initializes the state variable for the encoding or
+			the decoding algorithm. Each need a separate state
+			variable!!!
+
+rpeltp_delete ......... Delete the state variable allocation, etc (an alias).
+
+rpeltp_encode ......... Entry-level function for the encoding algorithm.
+
+rpeltp_decode ......... Entry-level function for the decoding algorithm.
+
+============================================================================
+*/
+#include <stdio.h>              /* For NULL */
+#include "private.h"
+#include "gsm.h"
+#include "rpeltp.h"
+
+/* *** Alias functions *** */
+/*
+  ------------------------------------------------------------------------
+  void rpeltp_delete(gsm_state *st);
+  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+  
+  Description:
+  ~~~~~~~~~~~~
+  Frees memory of a state variable previously initialized by a call to 
+  rpeltp_init(). This is an alias to the function gsm_destroy() implemented 
+  by the original authors of the module.
+  
+  Variables:
+  ~~~~~~~~~~
+  A pointer to a valid encoder or decoder state variable.
+  
+  Return value:
+  ~~~~~~~~~~~~~
+  None. 
+  
+  Prototype: in gsm.h
+  ~~~~~~~~~~
+  
+  Original author:
+  ~~~~~~~~~~~~~~~~
+   Simao Ferraz de Campos Neto
+   DDS/Pr11                      Tel: +55-192-39-6637
+   CPqD/Telebras                 Fax: +55-192-39-6125
+   13088-061 Campinas SP Brazil  E-mail: <simao@cpqd.ansp.br>
+   
+  Log of changes:
+  ~~~~~~~~~~~~~~~
+  12.Apr.94  v.1.0	created.
+
+  ------------------------------------------------------------------------
+*/
+/* #define rpeltp_delete gsm_destroy / * This is already done in rpeltp.h !!! */
+/* ................... End of rpeltp_delete() ......................... */
+
+
+/* *** True functions *** */
+
+/*
+  ------------------------------------------------------------------------
+  gsm_state *rpeltp_init(void);
+  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+  
+  Description:
+  ~~~~~~~~~~~~
+  Allocates memory for the state variable of the encoder or the decoder,
+  and resets flags to proper initial values. This includes processing
+  strictly according to the Rec. GSM 06.10.
+  
+  In a encoder plus decoder calling program there must exist different 
+  state variables for the encoder and for the decoder.
+  
+  Variables:
+  ~~~~~~~~~~
+  None.
+  
+  Return value:
+  ~~~~~~~~~~~~~
+  Returns a pointer to a valid encoder or decoder state variable. On 
+  failure, returns NULL.
+  
+  Prototype: in rpeltp.h
+  ~~~~~~~~~~
+  
+  Original author:
+  ~~~~~~~~~~~~~~~~
+   Simao Ferraz de Campos Neto
+   DDS/Pr11                      Tel: +55-192-39-6637
+   CPqD/Telebras                 Fax: +55-192-39-6125
+   13088-061 Campinas SP Brazil  E-mail: <simao@cpqd.ansp.br>
+   
+  Log of changes:
+  ~~~~~~~~~~~~~~~
+  12.Apr.94  v.1.0	created.
+
+  ------------------------------------------------------------------------
+*/
+gsm rpeltp_init()
+{
+  gsm rpe_state;
+  int gsm_compliant = 0;
+
+  /* Initializa state variable */
+  if (!(rpe_state = gsm_create()))
+    return ((gsm) (NULL));
+
+  /* The gsm_{en,de}code() routines may operate on a compliant mode, or
+   * in a non-compliant, faster mode - here we use the complyant one */
+  (void) gsm_option(rpe_state, GSM_OPT_FAST, &gsm_compliant);
+
+  return (rpe_state);
+}
+
+/* ................... End of rpeltp_init() ......................... */
+
+
+/*
+  ------------------------------------------------------------------------
+  void gsm_state *rpeltp_encode (gsm_state *rpe_state, short *inp_buf, 
+  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  short *rpe_frame);
+
+  
+  Description:
+  ~~~~~~~~~~~~
+  Process the input buffer inp_buf with left-aligned 16-bit linear-format,
+  2-complement samples using 13-bit resolution, i.e., the lower 3 bits of 
+  each input sample are ignored. 
+  
+  The rpe-ltp frame buffer rpe_frame is word-oriented (16-bit samples), 
+  right-aligned i.e., the lower bits are the most significatives. 
+  They follow the sequence specified by the `parameter number' in 
+  Table 1.1 of the Rec.GSM-06.10.
+  
+  The input buffer has always 160 samples, and the generated frame has 
+  always 76 samples.
+  
+  Variables:
+  ~~~~~~~~~~
+  rpe_state ... state variable initialized by a previous call to rpeltp_init()
+  inp_buf ..... pointer to a buffer with 160 16-bit, left aligned samples
+  rpe_frame ... pointer to a rpe-ltp encoded frame buffer. Has length of 76.
+                The samples are 16-bit, right-aligned.
+  
+  Return value:
+  ~~~~~~~~~~~~~
+  None.
+  
+  Prototype: in rpeltp.h
+  ~~~~~~~~~~
+  
+  Original author:
+  ~~~~~~~~~~~~~~~~
+   Simao Ferraz de Campos Neto
+   DDS/Pr11                      Tel: +55-192-39-6637
+   CPqD/Telebras                 Fax: +55-192-39-6125
+   13088-061 Campinas SP Brazil  E-mail: <simao@cpqd.ansp.br>
+   
+  Log of changes:
+  ~~~~~~~~~~~~~~~
+  12.Apr.94  v.1.0	created.
+
+  ------------------------------------------------------------------------
+*/
+void rpeltp_encode(rpe_state, inp_buf, rpe_frame)
+gsm rpe_state;
+short *inp_buf, *rpe_frame;
+{
+  gsm_frame rpe_packed_frame;
+
+  /* Run both and save decoded samples */
+  gsm_encode(rpe_state, inp_buf, rpe_packed_frame);
+  gsm_explode(rpe_state, rpe_packed_frame, rpe_frame);
+}
+
+/* ................... End of rpeltp_encode() ......................... */
+
+
+/*
+  ------------------------------------------------------------------------
+  void gsm_state *rpeltp_decode (gsm_state *rpe_state, short *rpe_frame, 
+  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  short *out_buf);
+
+  
+  Description:
+  ~~~~~~~~~~~~
+  Decode the input rpe-ltp encoded frame buffer rpe_buf with 76 righ-aligned 
+  16-bit samples, generating 160 decoded 16-bit, left-aligned linear 
+  2's-complement samples with 13-bit resolution, i.e., the lower 3 bits of 
+  each input sample are zeroed. These are saved in out_buf.
+  
+  The rpe-ltp frame buffer rpe_frame sample has the sequence specified by 
+  the `parameter number' in Table 1.1 of the Rec.GSM-06.10.
+  
+  Variables:
+  ~~~~~~~~~~
+  rpe_state ... state variable initialized by a previous call to rpeltp_init()
+  rpe_frame ... pointer to a rpe-ltp encoded frame buffer. Has length of 76.
+                The samples are 16-bit, right-aligned.
+  out_buf ..... pointer to the decode sample's buffer with 160 16-bit, 
+                left aligned samples
+  
+  Return value:
+  ~~~~~~~~~~~~~
+  None.
+  
+  Prototype: in rpeltp.h
+  ~~~~~~~~~~
+  
+  Original author:
+  ~~~~~~~~~~~~~~~~
+   Simao Ferraz de Campos Neto
+   DDS/Pr11                      Tel: +55-192-39-6637
+   CPqD/Telebras                 Fax: +55-192-39-6125
+   13088-061 Campinas SP Brazil  E-mail: <simao@cpqd.ansp.br>
+   
+  Log of changes:
+  ~~~~~~~~~~~~~~~
+  12.Apr.94  v.1.0	created.
+
+  ------------------------------------------------------------------------
+*/
+void rpeltp_decode(rpe_state, rpe_frame, out_buf)
+gsm rpe_state;
+short *out_buf, *rpe_frame;
+{
+  gsm_frame rpe_packed_frame;
+
+  /* Pack frame, run only the decoder and save the decoded samples */
+  gsm_implode(rpe_state, rpe_frame, rpe_packed_frame);
+  gsm_decode(rpe_state, rpe_packed_frame, out_buf);
+}
+
+/* ................... End of rpeltp_decode() ......................... */
+
+/* -------------------------- END OF RPELTP.C ------------------------ */

Repositories maintained by Peter Meerwald, pmeerw@pmeerw.net.