• Henrik Gramner's avatar
    checkasm: Use a self-balancing tree · 5405584b
    Henrik Gramner authored
    Tested functions are internally kept in a binary search tree for efficient
    lookups. The downside of the current implementation is that the tree quickly
    becomes unbalanced which causes an unneccessary amount of comparisons between
    nodes. Improve this by changing the tree into a self-balancing left-leaning
    red-black tree with a worst case lookup/insertion time complexity of O(log n).
    
    Significantly reduces the recursion depth and makes the tests run around 10%
    faster overall. The relative performance improvement compared to the existing
    non-balanced tree will also most likely increase as more tests are added.
    Signed-off-by: 's avatarAnton Khirnov <anton@khirnov.net>
    5405584b
Name
Last commit
Last update
compat Loading commit data...
doc Loading commit data...
libavcodec Loading commit data...
libavdevice Loading commit data...
libavfilter Loading commit data...
libavformat Loading commit data...
libavresample Loading commit data...
libavutil Loading commit data...
libswscale Loading commit data...
presets Loading commit data...
tests Loading commit data...
tools Loading commit data...
.gitattributes Loading commit data...
.gitignore Loading commit data...
.travis.yml Loading commit data...
COPYING.GPLv2 Loading commit data...
COPYING.GPLv3 Loading commit data...
COPYING.LGPLv2.1 Loading commit data...
COPYING.LGPLv3 Loading commit data...
CREDITS Loading commit data...
Changelog Loading commit data...
INSTALL Loading commit data...
LICENSE Loading commit data...
Makefile Loading commit data...
README Loading commit data...
README.md Loading commit data...
RELEASE Loading commit data...
arch.mak Loading commit data...
avconv.c Loading commit data...
avconv.h Loading commit data...
avconv_dxva2.c Loading commit data...
avconv_filter.c Loading commit data...
avconv_opt.c Loading commit data...
avconv_vda.c Loading commit data...
avconv_vdpau.c Loading commit data...
avplay.c Loading commit data...
avprobe.c Loading commit data...
cmdutils.c Loading commit data...
cmdutils.h Loading commit data...
cmdutils_common_opts.h Loading commit data...
common.mak Loading commit data...
configure Loading commit data...
library.mak Loading commit data...
version.sh Loading commit data...