47 lines
2.1 KiB
Plaintext
47 lines
2.1 KiB
Plaintext
|
The official guide to swresample for confused developers.
|
||
|
=========================================================
|
||
|
|
||
|
Current (simplified) Architecture:
|
||
|
---------------------------------
|
||
|
Input
|
||
|
v
|
||
|
__________________/|\___________
|
||
|
/ | \
|
||
|
/ input sample format convert v
|
||
|
/ | ___________/
|
||
|
| |/
|
||
|
| v
|
||
|
| ___________/|\___________ _____________
|
||
|
| / | \ | |
|
||
|
| Rematrix | resample <---->| Buffers |
|
||
|
| \___________ | ___________/ |_____________|
|
||
|
v \|/
|
||
|
Special Converter v
|
||
|
v ___________/|\___________ _____________
|
||
|
| / | \ | |
|
||
|
| Rematrix | resample <---->| Buffers |
|
||
|
| \___________ | ___________/ |_____________|
|
||
|
| \|/
|
||
|
| v
|
||
|
| |\___________
|
||
|
\ | \
|
||
|
\ output sample format convert v
|
||
|
\_________________ | ___________/
|
||
|
\|/
|
||
|
v
|
||
|
Output
|
||
|
|
||
|
Planar/Packed conversion is done when needed during sample format conversion.
|
||
|
Every step can be skipped without memcpy when it is not needed.
|
||
|
Either Resampling and Rematrixing can be performed first depending on which
|
||
|
way it is faster.
|
||
|
The Buffers are needed for resampling due to resamplng being a process that
|
||
|
requires future and past data, it thus also introduces inevitably a delay when
|
||
|
used.
|
||
|
Internally 32bit float and 16bit int is supported currently, other formats can
|
||
|
easily be added.
|
||
|
Externally all sample formats in packed and planar configuration are supported
|
||
|
It's also trivial to add special converters for common cases.
|
||
|
If only sample format and/or packed/planar conversion is needed, it
|
||
|
is performed from input to output directly in a single pass with no intermediates.
|