Man Linux: Main Page and Category List

NAME

     ch_wave - change/copy/combine waveform files

SYNOPSIS

     ch_wave [-h] [-itype file type] [-n channels] [-f sample rate]
             [-ibo byte order] [-iswap] [-istype sample type] [-c channel]
             [-start seconds] [-end seconds] [-from sample] [-to sample]
             [-o output file] [-otype file type] [-F sample rate]
             [-obo byte order] [-oswap] [-ostype sample type] [-scale factor]
             [-scaleN factor] [-lpfilter frequency] [-hpfilter freqency]
             [-forder order] [-fafter] [-info] [-add] [-pc LONGEST | FIRST]
             [-key keylab file] [-divide] [-ext file extension]
             [-extract file] input files ...

DESCRIPTION

     ch_wave performs various operations on an input waveform file and writes
     it out to another file.  Among other things, it can extract subsections
     or individual channels, resample, rescale, mix down channels, and perform
     simple filtering operations.

     The following option flags are recognized:

           -h    Options help
           -itype file type
                 Input file type (optional). If set to raw, this indicates
                 that the input file does not have a header. While this can be
                 used to specify file types other than raw, this is rarely
                 used for other purposes as the file type of all the existing
                 supported types can be determined automatically from the
                 file's header. If the input file is unheadered, files are
                 assumed to be shorts (16bit).  Supported types are nist, est,
                 esps, snd, riff, aiff, audlab, raw, ascii
           -n channels Number of channels in an unheadered input file
           -f sample rate
                 Sample rate in Hertz for an unheadered input file
           -ibo byte order
                 Input byte order in an unheadered input file: possibliities
                 are: MSB , LSB, native or nonnative. Suns, HP, SGI Mips,
                 M68000 are MSB (big endian) Intel, Alpha, DEC Mips, Vax are
                 LSB (little endian)
           -iswap
                 Swap bytes. (For use on an unheadered input file)
           -istype sample type
                 Sample type in an unheadered input file: short, alaw, mulaw,
                 byte, ascii
           -c channel
                 Select a single channel (starts from 0).  Waveforms can have
                 multiple channels. This option extracts a single channel for
                 progcessing and discards the rest.
           -start seconds
                 Extract sub-wave starting at this time, specified in seconds
           -end seconds
                 Extract sub-wave ending at this time, specified in seconds
           -from sample
                 Extract sub-wave starting at this sample point
           -to sample
                 Extract sub-wave ending at this sample point
           -o output file
                 Output filename. If not specified output is to stdout.
           -otype file type
                 Output file type, (optional). If no type is Specified the
                 type of the input file is assumed. Supported types are: nist,
                 est, esps, snd, riff, aiff, audlab, raw, ascii
           -F sample rate
                 Output sample rate in Hz. If this is different from the input
                 sample rate, resampling will occur
           -obo byte order
                 Output byte order: MSB, LSB, native, or nonnative. Suns, HP,
                 SGI Mips, M68000 are MSB (big endian), Intel, Alpha, DEC
                 Mips, Vax are LSB (little endian)
           -oswap
                 Swap bytes when saving to output
           -ostype sample type
                 Output sample type: short, alaw, mulaw, byte or ascii
           -scale factor
                 Scaling factor. Increase or descrease the amplitude of the
                 whole waveform by the factor given (relative to 1.0)
           -scaleN factor Scaling factor with normalization. The waveform is
                 scaled to its maximum level, after which it is scaled by the
                 factor given (relative to 1.0)
           -lpfilter frequency
                 Low pass filter, with cutoff frequency in Hz Filtering is
                 performed by a FIR filter which is built at run time. The
                 order of the filter can be given by -forder. The default
                 value is 199
           -hpfilter freqency
                 High pass filter, with cutoff frequency in Hz Filtering is
                 performed by a FIR filter which is built at run time. The
                 order of the filter can be given by -forder. The default
                 value is 199.
           -forder order
                 Order of FIR filter used for lpfilter and hpfilter. This must
                 be ODD. Sensible values range from 19 (quick but with a
                 shallow rolloff) to 199 (slow but with a steep rolloff). The
                 default is 199.
           -fafter
                 Do filtering after other operations such as resampling
                 (default : filter before other operations)
           -info
                 Print information about file and header. This option gives
                 useful information such as file length, sampling rate, number
                 of channels etc No output is produced
           -add  A new single channel waveform is created by adding the
                 corresponding sample points of each input waveform
           -pc LONGEST | FIRST
                 Combine input waveforms to form a single multichannel
                 waveform. The argument to this option controls how long the
                 new waveform should be. If the option is LONGEST, the output
                 wave if the length of the longest input wave and shorter
                 waves are padded with zeros at the end. If the option is
                 FIRST, the length of the new waveform is the length of the
                 first file on the command line, and subsequent waves are
                 padded or cut to this length
           -key keylab file
                 Label file designating subsections, for use with -divide. The
                 KEYLAB file is a label file which specifies where chunks
                 (such as individual sentences) in a waveform begin and end.
                 See section on wave extraction.
           -divide
                 Divide a single input waveform into multiple output
                 waveforms. Each output waveform is extracted from the input
                 waveform by using the KEYLAB file, which specifies the start
                 and stop times for each chunk. The output files are named
                 according to the filename in the KEYLAB file, with extension
                 given by -ext.  See section on wave extraction
           -ext file extension
                 File extension for divided waveforms
           -extract file
                 Used in conjunction with -key to extract a single section of
                 waveform from the input waveform. The argument is the name of
                 a file given in the file column of the KEYLAB file.

EXAMPLES

BUGS

SEE ALSO

     ch_track(1) ch_utt(1) na_record(1) na_play(1)