Pycodec2 is a Cython wrapper for Codec 2.
In other words, Pycodec2 allows using the Codec 2 C library from Python.
Pycodec2 requires Codec 2.
On Linux, I recommend using the distro's package-manager, e.g., on
Arch/Manjaro: pacman -Syuu codec2
, so that Codec2's assets land in standard
searchable directories for python setup.py
to use.
On macOS, you may use the Homebrew formula.
You can install the library using PyPI (the easiest option) or from source.
To install the library from PyPI, run:
pip install pycodec2
To install the library from source, see building instructions in DEV.md
. You
can then install the wheel with:
pip install dist/*.whl
Pycodec2 4.* is compatible with Codec 2 1.2.* and Numpy 2.*.
Pycodec2 3.* is compatible with Codec 2 1.2.*.
Pycodec2 2.* is compatible with Codec 2 1.0.*.
Pycodec2 1.0.* is compatible with Codec 2 at 0.9.2+ versions.
If your Codec 2 version is older than 0.9.2, then try pycodec2-old package.
For more information on potential compatibility problems, check out this issue.
example.py
implements a basic script that uses Codec 2 to encode and deencode
a sample. Use the following steps to run an end-2-end scenario (dev/rune2etest
implements steps 2-5).
-
Download a sample .wav file, e.g., trashcan.
-
Convert the .wav to a raw mono-channel 8kHz format, e.g.,
sox trashcan.wav -e signed-integer -b 16 trashcan.raw channels 1 rate 8000
-
Compile pycodec2
python setup.py build_ext --inplace
-
Run
example.py
python example.py trashcan.raw
-
Convert
output.raw
sox -r 8000 -e signed-integer -b 16 output.raw output.wav
Now you can listen to output.wav
.
Codec 2 assumes that input files use:
- 8kHz bitrate,
- 16-bit width samples,
- a single channel.
For a list of currently supported modes, look for _modes
in
pycodec2/pycodec2.pyx
.
This library is considered complete. Please notify me or send a pull request on GitHub if you notice any bugs.