The xvc codec is a next generation block-based video coding format built using world-class compression technologies.
Redistribution and use in source and binary form, with or without modifications is permitted only under the terms and conditions set forward in the xvc License Agreement.
Visit xvc.io for more information.
The following C++11 compilers have been known to work:
- Visual Studio 2015 or later
- GCC 4.8 or later
- Clang 3.3 or later
The following commands will checkout the project source code and create a directory called 'build' where the compiler output will be placed. CMake is then used for generating build files and compiling the xvc binaries.
$ git clone https://github.com/divideon/xvc.git
$ cd xvc
$ mkdir build
$ cd build
$ cmake ..
$ make
This will create xvc encoder and decoder binaries in the xvc/build/app/ folder.
The following commands will checkout the project source code and create a directory called 'build' where the compiler output will be placed. CMake is then used for generating build files and creating the Visual Studio solution.
$ git clone https://github.com/divideon/xvc.git
$ cd xvc
$ mkdir build
$ cd build
$ cmake -G "Visual Studio 14 2015 Win64" ..
The -G argument should be adjusted to match your version of Visual Studio and the target architecture. This will generate a Visual Studio solution called xvc.sln in the build folder. After building the solution, the xvc encoder and decoder binaries will be found in the xvc/build/app/Release/ folder.
For generating xvc bitstreams the following command shows typical usage:
$ xvcenc -input-file input.yuv -input-width 1920 -input-height 1080 \
-framerate 30 -output-file mybitstream.xvc -qp 32
For decoding an xvc bitstream use the xvcdec application:
$ xvcdec -bitstream-file mybitstream.xvc -output-file decoded.yuv
Both xvcenc and xvcdec supports reading and writing y4m output.
Pipes can be used together with e.g. ffmpeg to stream y4m input to encoder:
$ ffmpeg -i movie.mkv -f yuv4mpegpipe - | xvcenc -input-file - \
-qp 30 -output-file mybitstream.xvc
On the decoder, pipes can also be used to stream decoded output fo ffplay:
$ xvcdec -bitstream-file mybitstream.xvc -output-file - | ffplay -i -
To show all available encoder arguments run:
$ xvcenc -help
For decoder arguments run:
$ xvcdec -help
The xvc source code follows the Google C++ Style Guide.
For questions/comments please email [email protected]
Patches are encouraged, and may be submitted by forking this project and submitting a pull request through GitHub.
Please visit xvc.io for more information on how to become an xvc contributor.