Skip to main content

A cross-platform High-performance & Flexible Real-time Video Frames Decoder in Python.

Project description

DeFFcode

Build Status Codecov branch Azure DevOps builds (branch)

Glitter chat Build Status PyPi version

Code Style


Releases   |   Recipes   |   Documentation   |   Installation   |   License


DeFFcode - A cross-platform High-performance Video Frames Decoder that flexibly executes
FFmpeg pipeline inside a subprocess pipe for generating real-time, low-overhead,
lightning fast video frames with robust error-handling
in just a few lines of python code ⚡

Highly Adaptive - DeFFcode APIs implements a standalone highly-extensible wrapper around FFmpeg multimedia framework. These APIs supports a wide-ranging media streams as input source such as [live USB/Virtual/IP camera feeds][capturing-and-previewing-frames-from-a-webcam], regular multimedia files, screen recordings, image sequences, network URL schemes (such as HTTP(s), RTP/RSTP, etc.), so on and so forth.

Highly Flexible - DeFFcode APIs gains an edge over other FFmpeg Wrappers by providing complete control over the underline pipeline including access to almost any FFmpeg specification thinkable such as specifying framerate, resolution, hardware decoder(s), filtergraph(s), and pixel-format(s) that are readily supported by all well known Computer Vision libraries.

Highly Convenient - FFmpeg has a steep learning curve especially for users unfamiliar with a command line interface. DeFFcode helps users by providing similar to OpenCV, Index based Camera Device Capturing and the same standard OpenCV-Python (Python API for OpenCV) coding syntax for its APIs, thereby making it even easier to learn, create, and develop FFmpeg based apps in Python.

 

Key features of DeFFcode

Here are some key features that stand out:

  • High-performance, low-overhead video frames decoding with robust error-handling.
  • Flexible API with access to almost any FFmpeg specification thinkable.
  • Supports a wide-range of media streams/devices/protocols as input source.
  • Curated list of well-documented recipes ranging from Basic to Advanced skill levels.
  • Hands down the easiest Index based Camera Device Capturing, similar to OpenCV.
  • Easy to code Real-time Simple & Complex Filtergraphs. (Yes, You read it correctly "Real-time"!)
  • Lightning fast dedicated GPU-Accelerated Video Decoding & Transcoding.
  • Enables precise FFmpeg Key-frame Seeking with pinpoint accuracy.
  • Effortless Metadata Extraction from all streams available in the source.
  • Maintains the standard easy to learn OpenCV-Python coding syntax.
  • Out-of-the-box support for all prominent Computer Vision libraries.
  • Cross-platform, runs on Python 3.7+, and easy to install.

 

 

Getting Started


📚 Documentation: https://abhitronix.github.io/deffcode


Installation:

If this is your first time using DeFFcode, head straight to the Installation Notes to install DeFFcode on your machine.



Recipes a.k.a Examples:

Once you have DeFFcode installed, checkout our Well-Documented Recipes 🍱 for usage examples:

Note In case you're run into any problems, consult our Help section.

A. Basic Recipes 🍰: Recipes for beginners of any skill level to get started.



Big Buck Bunny Reversed using Live Simple Filtergraph

Basic Decoding Recipes
Basic Transcoding Recipes
Basic Metadata Recipes

B. Advanced Recipes 🥐: Recipes to take your skills to the next level.


mandelbrot test pattern
Live Mandelbrot pattern with a Vectorscope & two Waveforms


Advanced Decoding Recipes
Advanced Transcoding Recipes
Advanced Metadata Recipes


API in a nutshell:

As a user, you just have to remember only two DeFFcode APIs, namely:

A. FFdecoder API

The primary function of FFdecoder API is to decode 24-bit RGB video frames from the given source:

Note See API Reference for more in-depth information.

# import the necessary packages
from deffcode import FFdecoder

# formulate the decoder with suitable source
decoder = FFdecoder("https://abhitronix.github.io/html/Big_Buck_Bunny_1080_10s_1MB.mp4").formulate()

# grab RGB24(default) 3D frames from decoder
for frame in decoder.generateFrame():

    # lets print its shape
    print(frame.shape) # (1080, 1920, 3)

# terminate the decoder
decoder.terminate()

B. Sourcer API

The primary function of Sourcer API is to gather metadata information from all multimedia streams available in the given source:

# import the necessary packages
from deffcode import Sourcer

# initialize and formulate the decoder using suitable source
sourcer = Sourcer("https://abhitronix.github.io/html/Big_Buck_Bunny_1080_10s_1MB.mp4").probe_stream()

# print metadata as `json.dump`
print(sourcer.retrieve_metadata(pretty_json=True))
The resultant Terminal Output will look something as following on Windows machine
{
  "ffmpeg_binary_path": "C:\\Users\\foo\\AppData\\Local\\Temp\\ffmpeg-static-win64-gpl/bin/ffmpeg.exe",
  "source": "https://abhitronix.github.io/html/Big_Buck_Bunny_1080_10s_1MB.mp4",
  "source_extension": ".mp4",
  "source_video_resolution": [1920, 1080],
  "source_video_framerate": 60.0,
  "source_video_pixfmt": "yuv420p",
  "source_video_decoder": "h264",
  "source_duration_sec": 10.0,
  "approx_video_nframes": 600,
  "source_video_bitrate": "832k",
  "source_audio_bitrate": "",
  "source_audio_samplerate": "",
  "source_has_video": true,
  "source_has_audio": false,
  "source_has_image_sequence": false
}

 

 

Contributions

We're happy to meet new contributors💗

We welcome your contributions to help us improve and extend this project. If you want to get involved with DeFFcode development, checkout the Contribution Guidelines ▶️

We're offering support for DeFFcode on Gitter Community Channel. Come and join the conversation over there!

 

 

Donations

Donation

DeFFcode is free and open source and will always remain so. ❤️

It is something I am doing with my own free time. But so much more needs to be done, and I need your help to do this. For just the price of a cup of coffee, you can make a difference 🙂

Buy Me a Coffee at ko-fi.com

 

 

Citation

Here is a Bibtex entry you can use to cite this project in a publication:

DOI

@software{deffcode,
  author       = {Abhishek Thakur},
  title        = {abhiTronix/deffcode: v0.2.5},
  month        = jan,
  year         = 2023,
  publisher    = {Zenodo},
  version      = {v0.2.5},
  doi          = {10.5281/zenodo.7523792},
  url          = {https://doi.org/10.5281/zenodo.7523792}
}

 

 

Copyright

Copyright (c) abhiTronix 2021

This library is released under the Apache 2.0 License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

deffcode-0.2.6.tar.gz (61.4 kB view details)

Uploaded Source

Built Distribution

deffcode-0.2.6-py3-none-any.whl (41.9 kB view details)

Uploaded Python 3

File details

Details for the file deffcode-0.2.6.tar.gz.

File metadata

  • Download URL: deffcode-0.2.6.tar.gz
  • Upload date:
  • Size: 61.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.7

File hashes

Hashes for deffcode-0.2.6.tar.gz
Algorithm Hash digest
SHA256 7a3670c82a554316e3aafdcfd5755064fc0331b054817f8e6b7d81c549609692
MD5 d54dac87d6c6c95317cf3438ee435025
BLAKE2b-256 af386ed7bf78e4e48cff902299b806459ac2f0d650bd904522354bf5e8d989fe

See more details on using hashes here.

File details

Details for the file deffcode-0.2.6-py3-none-any.whl.

File metadata

  • Download URL: deffcode-0.2.6-py3-none-any.whl
  • Upload date:
  • Size: 41.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.7

File hashes

Hashes for deffcode-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 b832712940b3956e2b9fcf65af32807f5d8e91dfc140a95166c48ea110de33db
MD5 e33d6dc9fc441947030ebddd1196735e
BLAKE2b-256 7698808205666fa14d897e853b3c0dfd6f2fd9aa8e5ec7006bbce32877e839b8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page