diff intercom/g726/cvt_h_b.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/g726/cvt_h_b.c	Fri Jun 25 09:57:52 2010 +0200
@@ -0,0 +1,350 @@
+/*
+==============================================================================
+
+        CVT_H_B.C
+        ~~~~~~~~~
+
+        Program to convert ITU-T test sequences in hexa formats to
+        word oriented binary files. Each line is supposed to have 32 valid
+        samples (16 bit, or a word), or 64 hexa characters, either upper or
+        lower case. In the last line is expected one word (2 hexa chars)
+        in hexadecimal representation as the checksum of all the samples of
+        the file modulus 255 (sum mod 255).
+
+
+        USAGE:
+        ~~~~~~
+        $ cvt_h_b [-r] [-q] hex-in bin-out 
+        where:
+        hex-in          is the (input) hexadecimal file's name
+        bin-out         is the (output) binary file's name
+        
+        Options
+        ~~~~~~~
+        -q              Don't print progress indicator on the screen.
+        -r              is an optional parameter; if specified as r or R,
+                        even-bit reversal of all samples is accomplished 
+                        before saving the file. Default is NOT invert.
+
+        Compile:
+        ~~~~~~~~
+        SunC: cc -o cvt_h_b cvt_h_b.c # or #
+              acc -o cvt_h_b cvt_h_b.c
+        GNUC: gcc -o cvt_h_b cvt_h_b.c
+        VMS:  cc cvt_h_b.c
+              link cvt_h_b
+ 
+        History:
+        ~~~~~~~~
+        92.01.22   1.0   1st release by tdsimao@venus.cpqd.ansp.br
+        93.11.23   1.01  ported to SunOS (Unix)
+
+       =============================================================
+       COPYRIGHT NOTE: This source code, and all of its derivations,
+       is subject to the ITU-T General Public License". Please have
+       it  read  in    the  distribution  disk,   or  in  the  ITU-T
+       Recommendation G.191 on "SOFTWARE TOOLS FOR SPEECH AND  AUDIO
+       CODING STANDARDS".
+       =============================================================
+==============================================================================
+*/
+
+/* OS definition */
+#ifdef __MSDOS__                /* definition for automatic compil. under TurboC v2.0 */
+# define MSDOS                  /* this is already defined for Microsoft C 5.1 */
+#endif
+
+
+/* includes in general */
+#include <stdio.h>
+#include <stdlib.h>
+#include <math.h>
+
+
+/* Specific includes */
+#if defined(MSDOS)              /* for MSDOS */
+#  include <fcntl.h>
+#  include <io.h>
+#  include <sys\stat.h>
+#elif defined(VMS)              /* for VMS */
+#  include <perror.h>
+#  include <file.h>
+#  include <stat.h>
+#else                           /* for OTHER OS, in special UNIX */
+#  include <sys/stat.h>
+#endif
+
+
+/* Generic defines */
+#define askc(m,v) {printf(m); scanf("%c%*c",&v);}
+#define aski(m,v) {printf(m);scanf("%d",&v);}
+#define asks(m,v) {printf(m);gets(v);}
+#define KILL(str,code) {perror(str); exit(code);}
+#define GET_PAR_I(a,s,p,msg,i) {if(a>p) i=atoi(s[p]); else aski(msg,i);}
+#define GET_PAR_C(a,s,p,msg,c) {if(a>p) c=toupper(s[p][0]);else askc(msg,c);}
+#define GET_PAR_S(a,s,p,msg,S) {if(a>p) strcpy(S,s[p]); else asks(msg,S);}
+
+#if defined(VMS)
+#define WB  "wb","mrs=512","rfm=fix","ctx=stm"
+#define RB  "rb","mrs=512","rfm=fix","ctx=stm"
+#elif defined(MSDOS)
+#define WB  "wb"
+#define RB  "rb"
+#else
+#define WB  "w"
+#define RB  "r"
+#endif
+
+#define YES 1
+#define NO  0
+
+/* 
+ * --------------------------------------------------------------------------
+ * ... Calculate check-sum of a array of shorts ... 
+ *     Simao 07.Mar.94
+ * --------------------------------------------------------------------------
+ */
+short short_check_sum(s_data, n)
+short *s_data;
+long n;
+{
+  float csum = 0;
+  long i;
+
+  /* Add samples */
+  while (n)
+    csum += s_data[--n];
+
+  /* return mod as a short */
+  csum = fmod(csum, 255.0);
+  return ((short) csum);
+}
+
+
+/* 
+ * --------------------------------------------------------------------------
+ * ... Display usage of program ... 
+ *     Simao 10.Jan.93
+ * --------------------------------------------------------------------------
+ */
+#define FP(x) printf(x)
+void display_usage()
+{
+  FP("Version 1.01 of 23/Nov/1993 \n");
+
+  FP(" CVT_H_B.C:\n");
+  FP(" Program to convert ITU-T test sequences in hexa formats to\n");
+  FP(" word oriented binary files. Each line is supposed to have 32 valid\n");
+  FP(" samples (16 bit, or a word), or 64 hexa characters, either upper or\n");
+  FP(" lower case. In the last line is expected one word (2 hexa chars)\n");
+  FP(" in hexadecimal representation as the checksum of all the samples of\n");
+  FP(" the file modulus 255 (sum mod 255).\n");
+  FP("\n");
+  FP(" Usage:\n");
+  FP(" $ cvt_h_b [-r] hex-in bin-out\n");
+  FP(" where:\n");
+  FP("  hex-in          is the (input) hexadecimal file's name\n");
+  FP("  bin-out         is the (output) binary file's name\n\n");
+
+  FP(" Options\n");
+  FP("  -q              Don't print progress indicator on the screen\n");
+  FP("  -r              is an optional parameter; if specified as r or R,\n");
+  FP("                  even-bit reversal of all samples is accomplished \n");
+  FP("                  before saving the file. Default is NOT invert.\n");
+  FP("\n");
+
+  /* Quit program */
+  exit(-128);
+}
+
+#undef FP
+/* ....................... end of display_usage() ...........................*/
+
+
+/*============================== */
+main(argc, argv)
+int argc;
+char *argv[];
+/*============================== */
+{
+  char line[200], *lp;
+  char inpfil[50], outfil[50];
+  int inp, out, itmp, count = 0;
+  float check_sum = 0;
+  short scheck_sum = 0;
+  short chk;
+  short *bin, *tmp;
+  long leng, i, smpno = 0, lineno = 0;
+  int lastline_len = 0;
+
+  FILE *Fi, *Fo;
+  struct stat st;
+  int invert_even_bits = NO, quiet = NO;
+
+  static char funny[8] = { '\\', '-', '/', '|', '\\', '-', '/', '|' };
+
+
+  /* GETTING OPTIONS */
+
+  if (argc < 2)
+    display_usage();
+  else {
+    while (argc > 1 && argv[1][0] == '-')
+      if (strcmp(argv[1], "-r") == 0) {
+        /* Reverse even bits */
+        invert_even_bits = YES;
+
+        /* Move argv over the option to the next argument */
+        argv++;
+
+        /* Update argc */
+        argc--;
+      } else if (strcmp(argv[1], "-q") == 0) {
+        /* Don't print funny chars */
+        quiet = YES;
+
+        /* Move argv over the option to the next argument */
+        argv++;
+        argc--;
+      } else {
+        fprintf(stderr,
+          "ERROR! Invalid option \"%s\" in command line\n\n", argv[1]);
+        display_usage();
+      }
+  }
+
+
+
+  /* WELCOME! */
+
+  fprintf(stderr, "\n\t\tConversion from ITU-T HEX of test sequence");
+  fprintf(stderr, "\n\t\tfiles to binary files, 16 bits per sample\n");
+
+
+  /* GETTING PARAMETERS */
+
+  GET_PAR_S(argc, argv, 1, "_Input (ITU-T HEX) file: ....... ", inpfil);
+  GET_PAR_S(argc, argv, 2, "_Output (`short') file: ........ ", outfil);
+
+
+  /* OPEN FILES */
+
+  if ((Fi = fopen(inpfil, "r")) == NULL)
+    KILL(inpfil, 2);
+  if ((Fo = fopen(outfil, WB)) == NULL)
+    KILL(outfil, 3);
+  out = fileno(Fo);
+
+  /* FIND FILE SIZE AND ALLOC MEMORY FOR BINARY BUFFER */
+
+  stat(inpfil, &st);
+  if ((bin = (short *) malloc(st.st_size)) == (short *) NULL) {
+    fprintf(stderr, "\n Can't allocate memory for output buffer");
+    exit(4);
+  }
+  tmp = bin;
+
+
+  /* INFOS */
+
+  fprintf(stderr, "\n  Converting %s to %s\r", inpfil, outfil);
+
+
+  /* CONVERSION PART */
+
+  /* FIND NUMBER OF LINES IN FILE */
+  while (fgets(line, (int) 200, Fi) != NULL)
+    lineno++;
+  rewind(Fi);
+  lastline_len = strlen(line);
+  if (line[lastline_len - 1] = '\n')
+    lastline_len--;
+
+  /* READ ALL CHARS FOR THE FILE */
+  while (fgets(line, (int) 200, Fi) != NULL) {
+    /* Print `working' flag */
+    if (!quiet)
+      fprintf(stderr, "%c\r", funny[count % 8]);
+
+    /* Update line counter */
+    count++;
+
+    /* Remove CR from line end */
+    leng = strlen(line);
+    if (line[leng - 1] == '\n')
+      line[--leng] = '\0';
+
+    /* Convert line */
+    switch (leng) {
+    case 64:
+      for (lp = line, i = 0; i < leng; i += 2, lp += 2) {
+        sscanf(lp, "%2hx", tmp);
+        tmp++;
+        smpno++;
+      }
+      break;
+
+    case 2:
+      /* Check whether the last line */
+      if (count != lineno) {
+        /* If not, it's a regular sample */
+        sscanf(lp, "%2hx", tmp);
+        tmp++;
+        smpno++;
+      } else {
+        /* value is check-sum */
+        sscanf(line, "%2hx", &chk);
+      }
+      break;
+
+    default:                   /* for old (red-book) test sequences: initialization */
+      for (i = 0; i < leng - 2; i += 2) {
+        sscanf(&line[i], "%2hx", tmp);
+        tmp++;
+        smpno++;
+      }
+
+      /* Check sum for old files ... */
+      sscanf(&line[i], "%2hx", &chk);
+      break;
+
+    }
+  }
+
+  /* CALCULATE CHECK-SUMS */
+  scheck_sum = short_check_sum(bin, smpno);
+  fprintf(stderr, "Check-sum is: %d (calculated) %d (read)\n",
+    scheck_sum, chk);
+  if (chk != scheck_sum) {
+    fprintf(stderr, "\n Checksum Failed! (%d != %d)\n", chk,
+      scheck_sum);
+    exit(5);
+  }
+
+
+  /* INVERT EVEN BITS, IF IT IS THE CASE */
+
+  if (invert_even_bits) {
+    fprintf(stderr, "\r  Inverting even bits, as requested\t\t");
+    for (i = 0; i < (tmp - bin) / 2; i++)
+      bin[i] ^= 0x55;
+  }
+
+
+  /* SAVE TO FILE */
+
+  for (i = 0; i < smpno; i += 256) {
+    if (write(out, &bin[i], 512) != 512)
+      KILL(outfil, 6);
+  }
+
+
+  /* EXITING */
+
+  fprintf(stderr, "\rDone: %d samples converted!\n", smpno);
+  fclose(Fi);
+  fclose(Fo);
+#ifndef VMS
+  exit(0);
+#endif
+}

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