Skip to content

Commit

Permalink
Merge branch 'main' of github.com:kim-company/avx
Browse files Browse the repository at this point in the history
  • Loading branch information
dmorn committed Jun 5, 2024
2 parents 9a79fd8 + 2cefdfe commit c217653
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 12 deletions.
29 changes: 17 additions & 12 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@
Audio/Video Elixir. This is a libav (NIF) backed library for dealing with audio/video files. Takes
a functional approach allowing users to decide which runtime they want to design.

We use this library **in production** to demux/decode audio from the any browser's microphone to raw
format for doing realtime transcriptions (whisper, APIs, ecc).

## Installation
I'll publish it at some point if there is interest. For now,

Expand All @@ -18,25 +21,26 @@ end

## Requirements
* ffmpeg's libraries. `pkg-config` is used to find them. On macos `brew install ffmpeg`, debian sid `apt-get install -y -t sid pkg-config libfdk-aac-dev libavutil-dev libavcodec-dev libavformat-dev libavutil-dev libswresample-dev` (bullseye has an older version of libav* libs that are incompatible, sorry).
* You need `OTP >= 26.0.3` (we hit https://github.com/erlang/otp/issues/7292, believe it or not)
* You need `OTP >= 26.0.3` or `OTP ~25` (we hit https://github.com/erlang/otp/issues/7292, believe it or not)

## Features
- [x] demux any audio/video container (mp4, ogg, mkv, ...)
- [x] demux any audio container (mp4, ogg, mkv, ...)
- [x] decode audio files
- [ ] decode video files (in theory we should already be there, in practise the stream format for videos is not implemented and neither is the Frame "unpacking")
- [ ] mux streams

In the future it will support also encoding and muxing, in this order.

The term unpack is used here (probably incorrectly) to denote the action of
copying the packet/frame out of the C world into Elixir.

We're not targetting video files anymore for now, as we're do not need a fully-fledged
binding to ffmpeg at this time. If we're working with videos or complex setups, we're
still either using membrane or ffmpeg as above, but we did not generalize anything to
a library as of now.

## Before you start
- It will probably crash your BEAM at some point, as error handling is far from being complete on the C side. It is already pretty stable though.
- ~~It will probably crash your BEAM at some point, as error handling is far from being complete on the C side. It is already pretty stable though.~~

- NIFs are supposed to return in <1ms, which does not happen for some functions. I still
- ~~NIFs are supposed to return in <1ms, which does not happen for some functions. I still
need to measure the impact and determine the dirty scheduler that should be picked for each
function.
function.~~

## Usage
Check the tests, but in practice this is the flow for decoding audio from a
Expand Down Expand Up @@ -65,14 +69,15 @@ demuxer
|> Enum.into(output)
```

I'm currently working on a ThousandIsland Handler that can be used
to create a Demuxer source suitable for streaming setups.
To decode from a live session, use the ThousandIsland handler provided. It will
give you a `tcp://` endpoint you can use as file source to the demuxer. It carries
a little bit of overhead, but keeps the C side super simple.

And that's it. Compared to using the `ffmpeg` executable directly, here you have access
to every single packet, which you can re-route, manipulate and process at will.

This library is suitable as standalone or inside the elements of a [membrane](https://github.com/membraneframework)
pipeline for more complex setups (video mixers with dynamic inputs, WebRTC rooms, ...)
pipeline for more complex setups.

## Debugging
### Cocoa's way
Expand Down
4 changes: 4 additions & 0 deletions lib/avx.ex
Original file line number Diff line number Diff line change
@@ -1,2 +1,6 @@
defmodule AVx do
@spec pts_to_secs(pos_integer(), AVx.Demuxer.stream()) :: float()
def pts_to_secs(pts, stream) do
pts * stream.timebase_num / stream.timebase_den
end
end

0 comments on commit c217653

Please sign in to comment.