⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fixio.c

📁 无损音频压缩源码. 毕业设计 qq 64134703 更多毕业设计 www.rmlcd.cn
💻 C
字号:
/*******************************************************************************                                                                             **       Copyright (C) 1992-1996 Tony Robinson and SoftSound Ltd               **                                                                             **       See the file LICENSE for conditions on distribution and usage         **                                                                             *******************************************************************************//* * $Id: fixio.c,v 1.4 2002/01/28 01:16:52 jason Exp $ */#include <stdio.h>#include <stdlib.h>#include <string.h>#include "shorten.h"#include "bitshift.h"#ifdef HAVE_CONFIG_H#include "config.h"#endifextern int WriteWaveFile;#define CAPMAXSCHAR(x)  ((x > 127) ? 127 : x)#define CAPMAXUCHAR(x)  ((x > 255) ? 255 : x)#define CAPMAXSHORT(x)  ((x > 32767) ? 32767 : x)#define CAPMAXUSHORT(x) ((x > 65535) ? 65535 : x)static int sizeof_sample[TYPE_EOF];void init_sizeof_sample() {  sizeof_sample[TYPE_AU1]   = sizeof(uchar);  sizeof_sample[TYPE_S8]    = sizeof(schar);  sizeof_sample[TYPE_U8]    = sizeof(uchar);  sizeof_sample[TYPE_S16HL] = sizeof(sshort);  sizeof_sample[TYPE_U16HL] = sizeof(sshort);  sizeof_sample[TYPE_S16LH] = sizeof(sshort);  sizeof_sample[TYPE_U16LH] = sizeof(sshort);  sizeof_sample[TYPE_ULAW]  = sizeof(uchar);  sizeof_sample[TYPE_AU2]   = sizeof(uchar);  sizeof_sample[TYPE_AU3]   = sizeof(uchar);  sizeof_sample[TYPE_ALAW]  = sizeof(uchar);}/**************//* fixed read *//**************/static schar *readbuf, *readfub;static int  nreadbuf;void fread_type_init() {  init_sizeof_sample();  readbuf  = (schar*) NULL;  readfub  = (schar*) NULL;  nreadbuf = 0;}void fread_type_quit() {  if(readbuf != NULL) free(readbuf);  if(readfub != NULL) free(readfub);}/* read a file for a given data type and convert to signed long ints */int fread_type(data, ftype, nchan, nitem, stream, datalen) slong **data;  int ftype, nchan, nitem; FILE* stream; slong *datalen;{  int hiloint = 1, hilo = !(*((char*) &hiloint));  int i, nread, datasize = sizeof_sample[ftype], chan;  size_t nbyte = 0;  slong *data0 = data[0];  if (*datalen >= 0 && nchan * nitem * datasize > *datalen)    nitem = *datalen / (nchan * datasize);  if(nreadbuf < nchan * nitem * datasize) {    nreadbuf = nchan * nitem * datasize;    if(readbuf != NULL) free(readbuf);    if(readfub != NULL) free(readfub);    readbuf = (schar*) pmalloc((ulong) nreadbuf);    readfub = (schar*) pmalloc((ulong) nreadbuf);  }  switch(ftype) {  case TYPE_AU1:  case TYPE_S8:  case TYPE_U8:  case TYPE_ULAW:  case TYPE_AU2:  case TYPE_AU3:  case TYPE_ALAW:    nbyte = (size_t)fread((schar*) readbuf, 1 , datasize * nchan * nitem, stream);    break;  case TYPE_S16HL:  case TYPE_U16HL:    if(hilo)      nbyte = (size_t)fread((schar*) readbuf, 1 , datasize * nchan * nitem, stream);    else {      nbyte = (size_t)fread((schar*) readfub, 1 , datasize * nchan * nitem, stream);      swab(readfub, readbuf, nbyte);    }    break;  case TYPE_S16LH:  case TYPE_U16LH:    if(hilo) {      nbyte = fread((schar*) readfub, 1 , datasize * nchan * nitem, stream);      swab(readfub, readbuf, nbyte);    }    else      nbyte = fread((schar*) readbuf, 1 , datasize * nchan * nitem, stream);    break;  default:    update_exit(1, "can't read file type: %d\n", ftype);  }  bytes_read += nbyte;  if (*datalen > 0)    *datalen -= nbyte;  { int nextra = nbyte % (datasize * nchan);    if(nextra != 0)      usage_exit(1, "alignment problem: %d extra bytes\n", nextra);  }  nread = nbyte / (datasize * nchan);  switch(ftype) {  case TYPE_AU1:  case TYPE_AU2:  case TYPE_U8: {    uchar *readbufp = (uchar*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++)        data0[i] = *readbufp++;    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++)          data[chan][i] = *readbufp++;    break;  }  case TYPE_S8: {    schar *readbufp = (schar*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++)        data0[i] = *readbufp++;    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++)          data[chan][i] = *readbufp++;    break;  }  case TYPE_S16HL:  case TYPE_S16LH: {    sshort *readbufp = (sshort*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++)        data0[i] = *readbufp++;    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++)          data[chan][i] = *readbufp++;    break;  }  case TYPE_U16HL:  case TYPE_U16LH: {    ushort *readbufp = (ushort*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++)        data0[i] = *readbufp++;    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++)          data[chan][i] = *readbufp++;    break;  }  case TYPE_ULAW: {    uchar *readbufp = (uchar*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++)        data0[i] = Sulaw2linear(*readbufp++) >> 3;    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++)          data[chan][i] = Sulaw2linear(*readbufp++) >> 3;    break;  }  case TYPE_AU3: {    uchar *readbufp = (uchar*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++) {        int alaw = *readbufp++;        if(alaw < 128)          data0[i] = 127 - (alaw ^ 0xd5);        else          data0[i] = (alaw ^ 0x55) - 128;      }    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++) {          int alaw = *readbufp++;          if(alaw < 128)            data[chan][i] = 127 - (alaw ^ 0xd5);          else            data[chan][i] = (alaw ^ 0x55) - 128;        }    break;  }  case TYPE_ALAW: {    uchar *readbufp = (uchar*) readbuf;    if(nchan == 1)      for(i = 0; i < nread; i++)        data0[i] = Salaw2linear(*readbufp++) >> 3;    else      for(i = 0; i < nread; i++)        for(chan = 0; chan < nchan; chan++)          data[chan][i] = Salaw2linear(*readbufp++) >> 3;    break;  }  }  return(nread);}/***************//* fixed write *//***************/static char *writebuf, *writefub;static int  nwritebuf;void fwrite_type_init() {  init_sizeof_sample();  writebuf  = (schar*) NULL;  writefub  = (schar*) NULL;  nwritebuf = 0;}void fwrite_type_quit() {  if(writebuf != NULL) free(writebuf);  if(writefub != NULL) free(writefub);}/* convert from signed ints to a given type and write */void fwrite_type(data, ftype, nchan, nitem, stream) slong **data; int ftype,       nchan, nitem; FILE* stream; {  int hiloint = 1, hilo = !(*((char*) &hiloint));  int i, nwrite = nitem, datasize = sizeof_sample[ftype], chan;  slong *data0 = data[0];  if(nwritebuf < nchan * nitem * datasize) {    nwritebuf = nchan * nitem * datasize;    if(writebuf != NULL) free(writebuf);    if(writefub != NULL) free(writefub);    writebuf = (schar*) pmalloc((ulong) nwritebuf);    writefub = (schar*) pmalloc((ulong) nwritebuf);  }  switch(ftype) {  case TYPE_AU1: /* leave the conversion to fix_bitshift() */  case TYPE_AU2: {    uchar *writebufp = (uchar*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = data0[i];    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ = data[chan][i];    break;  }  case TYPE_U8: {    uchar *writebufp = (uchar*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = CAPMAXUCHAR(data0[i]);    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ =  CAPMAXUCHAR(data[chan][i]);    break;  }  case TYPE_S8: {    schar *writebufp = (schar*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = CAPMAXSCHAR(data0[i]);    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ = CAPMAXSCHAR(data[chan][i]);    break;  }  case TYPE_S16HL:  case TYPE_S16LH: {    sshort *writebufp = (sshort*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = CAPMAXSHORT(data0[i]);    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ = CAPMAXSHORT(data[chan][i]);    break;  }  case TYPE_U16HL:  case TYPE_U16LH: {    ushort *writebufp = (ushort*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = CAPMAXUSHORT(data0[i]);    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ = CAPMAXUSHORT(data[chan][i]);    break;  }  case TYPE_ULAW: {    uchar *writebufp = (uchar*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = Slinear2ulaw(CAPMAXSHORT((data0[i] << 3)));    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ = Slinear2ulaw(CAPMAXSHORT((data[chan][i] << 3)));    break;  }  case TYPE_AU3: {    uchar *writebufp = (uchar*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        if(data0[i] < 0)          *writebufp++ = (127 - data0[i]) ^ 0xd5;        else          *writebufp++ = (data0[i] + 128) ^ 0x55;    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          if(data[chan][i] < 0)            *writebufp++ = (127 - data[chan][i]) ^ 0xd5;          else            *writebufp++ = (data[chan][i] + 128) ^ 0x55;    break;  }  case TYPE_ALAW: {    uchar *writebufp = (uchar*) writebuf;    if(nchan == 1)      for(i = 0; i < nitem; i++)        *writebufp++ = Slinear2alaw(CAPMAXSHORT((data0[i] << 3)));    else      for(i = 0; i < nitem; i++)        for(chan = 0; chan < nchan; chan++)          *writebufp++ = Slinear2alaw(CAPMAXSHORT((data[chan][i] << 3)));    break;  }  }  switch(ftype) {  case TYPE_AU1:  case TYPE_S8:  case TYPE_U8:  case TYPE_ULAW:  case TYPE_AU2:  case TYPE_AU3:  case TYPE_ALAW:    if(WriteWaveFile)      nwrite = fwrite((schar*) writebuf, datasize * nchan, nitem, stream);    break;  case TYPE_S16HL:  case TYPE_U16HL:    if(hilo)    {      if(WriteWaveFile)        nwrite = fwrite((schar*) writebuf, datasize * nchan, nitem, stream);    }    else    {      swab(writebuf, writefub, (size_t)(datasize * nchan * nitem));      if(WriteWaveFile)        nwrite = fwrite((schar*) writefub, datasize * nchan, nitem, stream);    }    break;  case TYPE_S16LH:  case TYPE_U16LH:    if(hilo)    {      swab(writebuf, writefub, (size_t)(datasize * nchan * nitem));      if(WriteWaveFile)        nwrite = fwrite((schar*) writefub, datasize * nchan, nitem, stream);    }    else    {     if(WriteWaveFile)       nwrite = fwrite((schar*) writebuf, datasize * nchan, nitem, stream);    }    break;  }  if(nwrite != nitem)    update_exit(1, "failed to write decompressed stream\n");}/*************//* bitshifts *//*************/int find_bitshift(data, nitem, ftype) slong *data; int nitem, ftype; {  int i, bitshift;  if(ftype == TYPE_AU1 || ftype == TYPE_AU2) {    bitshift = NBITPERLONG;    for(i = 0; i < nitem &&      (bitshift = MIN(bitshift, ulaw_maxshift[data[i]])) != 0; i++);    if(ftype == TYPE_AU1)      for(i = 0; i < nitem; i++)        data[i] = ulaw_inward[bitshift][data[i]];    else      for(i = 0; i < nitem; i++) {        if(data[i] > NEGATIVE_ULAW_ZERO)          data[i] = ulaw_inward[bitshift][data[i]];        else if(data[i] == NEGATIVE_ULAW_ZERO)          data[i] = -1;        else          data[i] = ulaw_inward[bitshift][data[i]] - 1;      }  }  else {    int hash = 0;    for(i = 0; i < nitem && ((hash |= data[i]) & 1) == 0; i++);    if(hash != 0) {      for(bitshift = 0; (hash & 1) == 0; bitshift++) hash >>= 1;      if(bitshift != 0)        for(i = 0; i < nitem; i++) data[i] >>= bitshift;    }    else      bitshift = NBITPERLONG;  }  return(bitshift);}void fix_bitshift(buffer, nitem, bitshift, ftype) slong *buffer; int nitem,       bitshift, ftype; {  int i;  if(ftype == TYPE_AU1)    for(i = 0; i < nitem; i++)      buffer[i] = ulaw_outward[bitshift][buffer[i] + 128];  else if(ftype == TYPE_AU2)    for(i = 0; i < nitem; i++) {      if(buffer[i] >= 0)        buffer[i] = ulaw_outward[bitshift][buffer[i] + 128];      else if(buffer[i] == -1)        buffer[i] =  NEGATIVE_ULAW_ZERO;      else        buffer[i] = ulaw_outward[bitshift][buffer[i] + 129];    }  else    if(bitshift != 0)      for(i = 0; i < nitem; i++)        buffer[i] <<= bitshift;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -