Skip to content

viciious/VocTool

 
 

Repository files navigation

VocTool

This project provides a tool to convert WAVE file into 8bit Creative VOC files, including ADPCM compression. Currently 2bit and 4bit ADPCM are supported.

The resulting VOC file is always in mono.

Usage of encoder

Usage of voctool
Usage: voctool -i INPUT -o OUTPUT [ -f FREQUENCY ] [ -c COMPRESSION ] [ -n NORMALIZE ] [ -l LEVEL ] [ -C CUTOFF ] [ -T TRANSITION ]

Program to convert WAVE files into VOC files including optional ADPCM compression.
Conversion from VOC to WAVE is also supported.
File is converted to mono. If a frequency is give then the file is also resampled
to the given frequency. Otherwise the sample frequency of the WAVE file is kept.

Compression formats:
  PCM    - unsigned integer 8-bit per sample
  ADPCM4 - ADPCM 4-bit per sample
  ADPCM2 - ADPCM 2-bit per sample


options:
  -i, --input        Name of the input file
  -o, --output       Name of the output file
  -f, --frequency    Frequency of output file in hertz
  -c, --compression  Compression to be used. Options: PCM, ADPCM4, ADPCM2 ( default: ADPCM4 )
  -n, --normalize    Normalize audio to given fraction, e.g. 0.9
  -l, --level        Level of compression. Must be integer. 1 = lowest quality but fast. Bigger values than 5 probably make no sense and are terribly slow. ( default: 4 )
  -C, --cutoff       Cutoff frequency for lowpass filter in Hz. Default is half of sampling frequency.
  -T, --transition   Transition bandwidth for lowpass filter in Hz. Default is 1/10 of sampling frequency.

Examples

Encoding a WAVE file into VOC format. A conversion to 8000Hz and ADPCM4 compression is done. The volume is normalized to 70%.
voctool -i sound.wav -f 8000 -c ADPCM4 -o sound.voc -n 0.7
Decoding a VOC file into WAVE format. Currently decoding VOC files does not support changing of the frequency or compression. The WAVE will always be 8bit PCM.
voctool -i sound.voc -o sound.wav

Choosing the right ADPCM compression level

The tool supports the option to set the compression level. The compression level is a number between 1 and 8. The level defines the number of samples that are combined during compression. If a number of 4 is chosen that means that the algorithm will exhastively try every combination of 4 samples to find the best compression. For ADPCM4 this means that incremeting the level by 1 will increase the runtime by a factor of 16. For ADPCM2 the factor is 4.

For ADPCM4 the level 4 seems to be a good compromise between quality and speed.

For ADPCM2 the level 7 seems to be a good compromise.

About Creative ADPCM

Creative ADPCM compresses an 8bit per sample sound file into a 4bit/2bit per sample sound file. This halves/quaters the required space, but also decreases the sound quality. This works by only storing the difference to the previous sample.

About this encoder

I wrote this encoder because I needed a Creative ADPCM encoder for my MSDOS platform game. At first I looked for already existing encoders, but there actually were no free encoders available. The only (non free) encoder I could find was the tool VOCEDIT 2 (see http://www.vogons.org/viewtopic.php?t=8634). Unfortunately that tool only runs on DOS and it is also a GUI tool that does not support scripting. I actually got VOCEDIT 2 to run using Dosbox but because of the fact that it is not scriptable and also not free, I decided to build an encoder myself.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 96.9%
  • CMake 2.5%
  • Shell 0.6%