diff intercom/g711/shiftbit.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/g711/shiftbit.c	Fri Jun 25 09:57:52 2010 +0200
@@ -0,0 +1,120 @@
+/*
+   =======================================================================
+
+   SHIFTBIT.C
+   ~~~~~~~~~~
+
+   Description
+   ~~~~~~~~~~~
+
+   Shift samples from input file (in Qx format) such that the output file
+   will be in the Qy format, with sign extension. In fact, what this does
+   is multiply by the factor 2**(y-x) (if left-shift) or divide by the
+   factor 2**(x-y) (if right-shift) the input samples.
+
+   Includes:
+   ~~~~~~~~~
+      specific: ugstdemo.h
+      system:   stdio.h,stat.h
+
+   Author:
+   ~~~~~~~
+
+   Simao Ferraz de Campos Neto
+   DDS/Pr11                      Tel: +55-192-39-1396                
+   CPqD/Telebras                 Fax: +55-192-53-4754                
+   13085 Campinas SP Brazil      E-mail: <tdsimao@venus.cpqd.ansp.br>
+                                       
+   History:
+   ~~~~~~~~
+   08.Feb.91 v1.0 Created!
+
+   =======================================================================
+*/
+
+#include "ugstdemo.h"
+#include <stdio.h>
+
+/* 
+ * Includes dependent of the Operating System 
+ */
+#if defined(VMS)
+# include <stat.h>
+#elif defined (MSDOS)
+# include <sys\stat.h>
+#else
+# include <sys/stat.h>
+#endif
+
+#define RIGHT 1
+#define LEFT -1
+
+main(argc, argv)
+int argc;
+char *argv[];
+{
+  char inp[50], out[50];
+  short *buf;
+  int qinp, qout, shift, dir;
+  FILE *Fi, *Fo;
+  int fi, fo;
+#ifdef VMS
+  char mrs[15] = "mrs=512";
+#endif
+  struct stat info;
+  long l, k;
+
+  GET_PAR_S(1, "Input file: ......... ", inp);
+  GET_PAR_I(2, "Input file is Q.", qinp);
+  GET_PAR_S(3, "Output file: ........ ", out);
+  GET_PAR_I(4, "Input file is Q.", qout);
+
+  if (qout == qinp)
+    HARAKIRI("Makes no sense a shift of 0 ... \n", 7)
+      else
+  if (qout > qinp)
+    dir = RIGHT;
+  else
+    dir = LEFT;
+
+  l = qout - qinp;
+  if (l < 0)
+    l = -l;
+
+  for (shift = 1, k = 0; k < l; k++)
+    shift *= 2;
+
+  if ((Fi = fopen(inp, RB)) == NULL)
+    KILL(inp, 2);
+  fi = fileno(Fi);
+  if ((Fo = fopen(out, WB)) == NULL)
+    KILL(inp, 3);
+  fo = fileno(Fo);
+
+  stat(inp, &info);
+  if ((buf = (short *) malloc(info.st_size)) == NULL)
+    HARAKIRI("Can't alloc inp\n", 4);
+  l = info.st_size / 2;
+
+  fprintf(stderr, "%s: Reading, ", inp);
+  for (k = 0; k < l; k += 256)
+    if (read(fi, &buf[k], 512) < 0)
+      KILL(inp, 5);
+
+  fprintf(stderr, "shifting, ");
+  if (dir == RIGHT)
+    for (k = 0; k < l; k++)
+      buf[k] = (buf[k] * shift);
+  else
+    for (k = 0; k < l; k++)
+      buf[k] = (buf[k] / shift);
+
+  fprintf(stderr, "and writing ... ");
+  for (k = 0; k < l; k += 256)
+    if (write(fo, &buf[k], 512) <= 0)
+      KILL(inp, 6);
+
+  fprintf(stderr, "Done!\n");
+  fclose(Fi);
+  fclose(Fo);
+}

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