Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Save Kamino666/09f878289e1e6dc13b0a3b2b508d68a5 to your computer and use it in GitHub Desktop.
Save Kamino666/09f878289e1e6dc13b0a3b2b508d68a5 to your computer and use it in GitHub Desktop.
针对Python中各种读取视频库的比较
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {
"id": "dNF-t2FO1M6r"
},
"source": [
"# Benchmark of Video Reader in Python\n",
"\n",
"比较Python中的各种读取视频的实现\n",
"\n",
"This notebook compares several video reader in Python.\n",
"\n",
"1. OpenCV(cv2)\n",
"2. Decord\n",
"3. MMCV\n",
"4. pyAV"
]
},
{
"cell_type": "markdown",
"source": [
"安装一个新版本的ffmpeg"
],
"metadata": {
"id": "v3mbqj2_50BR"
}
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "hDsdrVMS_YFX",
"outputId": "ad257ab8-daad-4b61-e9e7-bf58d2c3713c"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Cloning into 'ffmpeg-colab'...\n",
"remote: Enumerating objects: 19, done.\u001b[K\n",
"remote: Counting objects: 100% (5/5), done.\u001b[K\n",
"remote: Compressing objects: 100% (5/5), done.\u001b[K\n",
"remote: Total 19 (delta 3), reused 0 (delta 0), pack-reused 14\u001b[K\n",
"Unpacking objects: 100% (19/19), done.\n",
"FFmpeg was found at /usr/bin/ffmpeg\n",
"Removing old FFmpeg\n",
"Done\n",
"Moving new ffmpeg to /usr/bin\n",
"FFmpeg was successfully installed\n"
]
}
],
"source": [
"!git clone https://github.com/XniceCraft/ffmpeg-colab.git\n",
"!sudo bash ./ffmpeg-colab/install"
]
},
{
"cell_type": "markdown",
"source": [
"安装各种库"
],
"metadata": {
"id": "wvM7RzXW5zU6"
}
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "zc3_BslhGo7k",
"outputId": "3f8237e7-036a-4eaf-8eae-607ececf2f2b"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
"Collecting youtube-dl\n",
" Downloading youtube_dl-2021.12.17-py2.py3-none-any.whl (1.9 MB)\n",
"\u001b[K |████████████████████████████████| 1.9 MB 7.3 MB/s \n",
"\u001b[?25hInstalling collected packages: youtube-dl\n",
"Successfully installed youtube-dl-2021.12.17\n",
"Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
"Collecting memory_profiler\n",
" Downloading memory_profiler-0.60.0.tar.gz (38 kB)\n",
"Requirement already satisfied: psutil in /usr/local/lib/python3.7/dist-packages (from memory_profiler) (5.4.8)\n",
"Building wheels for collected packages: memory-profiler\n",
" Building wheel for memory-profiler (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
" Created wheel for memory-profiler: filename=memory_profiler-0.60.0-py3-none-any.whl size=31284 sha256=1da91e7a81ad45b33dbf0306f36d941dfc2ac8a7053756787e1292632a13ce6c\n",
" Stored in directory: /root/.cache/pip/wheels/67/2b/fb/326e30d638c538e69a5eb0aa47f4223d979f502bbdb403950f\n",
"Successfully built memory-profiler\n",
"Installing collected packages: memory-profiler\n",
"Successfully installed memory-profiler-0.60.0\n",
"Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
"Collecting mmcv\n",
" Downloading mmcv-1.6.1.tar.gz (563 kB)\n",
"\u001b[K |████████████████████████████████| 563 kB 7.2 MB/s \n",
"\u001b[?25hCollecting addict\n",
" Downloading addict-2.4.0-py3-none-any.whl (3.8 kB)\n",
"Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from mmcv) (1.21.6)\n",
"Requirement already satisfied: packaging in /usr/local/lib/python3.7/dist-packages (from mmcv) (21.3)\n",
"Requirement already satisfied: Pillow in /usr/local/lib/python3.7/dist-packages (from mmcv) (7.1.2)\n",
"Requirement already satisfied: pyyaml in /usr/local/lib/python3.7/dist-packages (from mmcv) (6.0)\n",
"Collecting yapf\n",
" Downloading yapf-0.32.0-py2.py3-none-any.whl (190 kB)\n",
"\u001b[K |████████████████████████████████| 190 kB 63.5 MB/s \n",
"\u001b[?25hRequirement already satisfied: pyparsing!=3.0.5,>=2.0.2 in /usr/local/lib/python3.7/dist-packages (from packaging->mmcv) (3.0.9)\n",
"Building wheels for collected packages: mmcv\n",
" Building wheel for mmcv (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
" Created wheel for mmcv: filename=mmcv-1.6.1-py2.py3-none-any.whl size=860296 sha256=9fc51c5967cfe708fa7b505cbbbbdfbc8508540ec00591aafc79f17ab0d34d1e\n",
" Stored in directory: /root/.cache/pip/wheels/e0/43/68/40160e8aa085d474903f0ad3764bac92e698936bfcf8a5454b\n",
"Successfully built mmcv\n",
"Installing collected packages: yapf, addict, mmcv\n",
"Successfully installed addict-2.4.0 mmcv-1.6.1 yapf-0.32.0\n",
"Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
"Collecting av\n",
" Downloading av-9.2.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (28.2 MB)\n",
"\u001b[K |████████████████████████████████| 28.2 MB 1.5 MB/s \n",
"\u001b[?25hInstalling collected packages: av\n",
"Successfully installed av-9.2.0\n"
]
}
],
"source": [
"!sudo -H pip install --upgrade youtube-dl\n",
"!pip install -U memory_profiler\n",
"# !pip install decord\n",
"!pip install mmcv\n",
"!pip install av"
]
},
{
"cell_type": "markdown",
"source": [
"安装GPU版本的Decord"
],
"metadata": {
"id": "1NGuLGJOWyuH"
}
},
{
"cell_type": "code",
"source": [
"!sudo apt-get update\n",
"!sudo apt-get install -y build-essential python3-dev python3-setuptools make cmake\n",
"!sudo apt-get install -y libavcodec-dev libavfilter-dev libavformat-dev libavutil-dev\n",
"!git clone --recursive https://github.com/dmlc/decord\n",
"%cd decord\n",
"!mkdir build\n",
"%cd build\n",
"!cmake .. -DUSE_CUDA=ON -DCMAKE_BUILD_TYPE=Release \n",
"!make\n",
"%cd /content/decord/python\n",
"!python setup.py install --user\n",
"%cd /content"
],
"metadata": {
"id": "OBEihCBlSbSF",
"colab": {
"base_uri": "https://localhost:8080/"
},
"outputId": "f55a8ee4-5222-4f85-e4f8-5bfb6663f0d0"
},
"execution_count": 3,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"\r0% [Working]\r \rGet:1 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran40/ InRelease [3,626 B]\n",
"\r0% [Connecting to archive.ubuntu.com (185.125.190.36)] [Connecting to security.\r0% [Connecting to archive.ubuntu.com (185.125.190.36)] [Connecting to security.\r0% [1 InRelease gpgv 3,626 B] [Connecting to archive.ubuntu.com (185.125.190.36\r \rIgn:2 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 InRelease\n",
"\r0% [1 InRelease gpgv 3,626 B] [Connecting to archive.ubuntu.com (185.125.190.36\r \rGet:3 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64 InRelease [1,581 B]\n",
"Hit:4 https://developer.download.nvidia.com/compute/machine-learning/repos/ubuntu1804/x86_64 Release\n",
"Get:5 http://security.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]\n",
"Get:6 https://cloud.r-project.org/bin/linux/ubuntu bionic-cran40/ Packages [91.1 kB]\n",
"Get:7 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64 Packages [912 kB]\n",
"Hit:8 http://archive.ubuntu.com/ubuntu bionic InRelease\n",
"Get:9 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic InRelease [15.9 kB]\n",
"Get:11 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]\n",
"Get:12 http://security.ubuntu.com/ubuntu bionic-security/main amd64 Packages [2,939 kB]\n",
"Hit:13 http://ppa.launchpad.net/cran/libgit2/ubuntu bionic InRelease\n",
"Get:14 http://archive.ubuntu.com/ubuntu bionic-backports InRelease [74.6 kB]\n",
"Hit:15 http://ppa.launchpad.net/deadsnakes/ppa/ubuntu bionic InRelease\n",
"Hit:16 http://ppa.launchpad.net/graphics-drivers/ppa/ubuntu bionic InRelease\n",
"Get:17 http://security.ubuntu.com/ubuntu bionic-security/universe amd64 Packages [1,534 kB]\n",
"Get:18 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 Packages [2,311 kB]\n",
"Get:19 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic/main Sources [2,094 kB]\n",
"Get:20 http://archive.ubuntu.com/ubuntu bionic-updates/main amd64 Packages [3,369 kB]\n",
"Get:21 http://ppa.launchpad.net/c2d4u.team/c2d4u4.0+/ubuntu bionic/main amd64 Packages [1,073 kB]\n",
"Fetched 14.6 MB in 4s (4,064 kB/s)\n",
"Reading package lists... Done\n",
"Reading package lists... Done\n",
"Building dependency tree \n",
"Reading state information... Done\n",
"build-essential is already the newest version (12.4ubuntu1).\n",
"make is already the newest version (4.1-9.1ubuntu1).\n",
"make set to manually installed.\n",
"cmake is already the newest version (3.10.2-1ubuntu2.18.04.2).\n",
"python3-dev is already the newest version (3.6.7-1~18.04).\n",
"python3-dev set to manually installed.\n",
"The following package was automatically installed and is no longer required:\n",
" libnvidia-common-460\n",
"Use 'sudo apt autoremove' to remove it.\n",
"The following additional packages will be installed:\n",
" python3-pkg-resources\n",
"Suggested packages:\n",
" python-setuptools-doc\n",
"The following NEW packages will be installed:\n",
" python3-pkg-resources python3-setuptools\n",
"0 upgraded, 2 newly installed, 0 to remove and 43 not upgraded.\n",
"Need to get 346 kB of archives.\n",
"After this operation, 1,848 kB of additional disk space will be used.\n",
"Get:1 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-pkg-resources all 39.0.1-2 [98.8 kB]\n",
"Get:2 http://archive.ubuntu.com/ubuntu bionic/main amd64 python3-setuptools all 39.0.1-2 [248 kB]\n",
"Fetched 346 kB in 1s (653 kB/s)\n",
"debconf: unable to initialize frontend: Dialog\n",
"debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 76, <> line 2.)\n",
"debconf: falling back to frontend: Readline\n",
"debconf: unable to initialize frontend: Readline\n",
"debconf: (This frontend requires a controlling tty.)\n",
"debconf: falling back to frontend: Teletype\n",
"dpkg-preconfigure: unable to re-open stdin: \n",
"Selecting previously unselected package python3-pkg-resources.\n",
"(Reading database ... 155676 files and directories currently installed.)\n",
"Preparing to unpack .../python3-pkg-resources_39.0.1-2_all.deb ...\n",
"Unpacking python3-pkg-resources (39.0.1-2) ...\n",
"Selecting previously unselected package python3-setuptools.\n",
"Preparing to unpack .../python3-setuptools_39.0.1-2_all.deb ...\n",
"Unpacking python3-setuptools (39.0.1-2) ...\n",
"Setting up python3-pkg-resources (39.0.1-2) ...\n",
"Setting up python3-setuptools (39.0.1-2) ...\n",
"Reading package lists... Done\n",
"Building dependency tree \n",
"Reading state information... Done\n",
"libavcodec-dev is already the newest version (7:3.4.11-0ubuntu0.1).\n",
"libavcodec-dev set to manually installed.\n",
"libavformat-dev is already the newest version (7:3.4.11-0ubuntu0.1).\n",
"libavformat-dev set to manually installed.\n",
"libavutil-dev is already the newest version (7:3.4.11-0ubuntu0.1).\n",
"libavutil-dev set to manually installed.\n",
"The following package was automatically installed and is no longer required:\n",
" libnvidia-common-460\n",
"Use 'sudo apt autoremove' to remove it.\n",
"The following additional packages will be installed:\n",
" libpostproc-dev\n",
"The following NEW packages will be installed:\n",
" libavfilter-dev libpostproc-dev\n",
"0 upgraded, 2 newly installed, 0 to remove and 43 not upgraded.\n",
"Need to get 1,067 kB of archives.\n",
"After this operation, 5,019 kB of additional disk space will be used.\n",
"Get:1 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 libpostproc-dev amd64 7:3.4.11-0ubuntu0.1 [51.0 kB]\n",
"Get:2 http://archive.ubuntu.com/ubuntu bionic-updates/universe amd64 libavfilter-dev amd64 7:3.4.11-0ubuntu0.1 [1,016 kB]\n",
"Fetched 1,067 kB in 1s (1,714 kB/s)\n",
"debconf: unable to initialize frontend: Dialog\n",
"debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 76, <> line 2.)\n",
"debconf: falling back to frontend: Readline\n",
"debconf: unable to initialize frontend: Readline\n",
"debconf: (This frontend requires a controlling tty.)\n",
"debconf: falling back to frontend: Teletype\n",
"dpkg-preconfigure: unable to re-open stdin: \n",
"Selecting previously unselected package libpostproc-dev:amd64.\n",
"(Reading database ... 155789 files and directories currently installed.)\n",
"Preparing to unpack .../libpostproc-dev_7%3a3.4.11-0ubuntu0.1_amd64.deb ...\n",
"Unpacking libpostproc-dev:amd64 (7:3.4.11-0ubuntu0.1) ...\n",
"Selecting previously unselected package libavfilter-dev:amd64.\n",
"Preparing to unpack .../libavfilter-dev_7%3a3.4.11-0ubuntu0.1_amd64.deb ...\n",
"Unpacking libavfilter-dev:amd64 (7:3.4.11-0ubuntu0.1) ...\n",
"Setting up libpostproc-dev:amd64 (7:3.4.11-0ubuntu0.1) ...\n",
"Setting up libavfilter-dev:amd64 (7:3.4.11-0ubuntu0.1) ...\n",
"Cloning into 'decord'...\n",
"remote: Enumerating objects: 3211, done.\u001b[K\n",
"remote: Counting objects: 100% (300/300), done.\u001b[K\n",
"remote: Compressing objects: 100% (169/169), done.\u001b[K\n",
"remote: Total 3211 (delta 130), reused 256 (delta 103), pack-reused 2911\u001b[K\n",
"Receiving objects: 100% (3211/3211), 20.70 MiB | 29.89 MiB/s, done.\n",
"Resolving deltas: 100% (1941/1941), done.\n",
"Submodule '3rdparty/dlpack' (https://github.com/dmlc/dlpack) registered for path '3rdparty/dlpack'\n",
"Submodule '3rdparty/dmlc-core' (https://github.com/dmlc/dmlc-core) registered for path '3rdparty/dmlc-core'\n",
"Cloning into '/content/decord/3rdparty/dlpack'...\n",
"remote: Enumerating objects: 437, done. \n",
"remote: Counting objects: 100% (106/106), done. \n",
"remote: Compressing objects: 100% (43/43), done. \n",
"remote: Total 437 (delta 78), reused 68 (delta 61), pack-reused 331 \n",
"Receiving objects: 100% (437/437), 1.69 MiB | 7.53 MiB/s, done.\n",
"Resolving deltas: 100% (148/148), done.\n",
"Cloning into '/content/decord/3rdparty/dmlc-core'...\n",
"remote: Enumerating objects: 6284, done. \n",
"remote: Counting objects: 100% (148/148), done. \n",
"remote: Compressing objects: 100% (108/108), done. \n",
"remote: Total 6284 (delta 54), reused 74 (delta 24), pack-reused 6136 \n",
"Receiving objects: 100% (6284/6284), 1.68 MiB | 10.37 MiB/s, done.\n",
"Resolving deltas: 100% (3800/3800), done.\n",
"Submodule path '3rdparty/dlpack': checked out '5c792cef3aee54ad8b7000111c9dc1797f327b59'\n",
"Submodule path '3rdparty/dmlc-core': checked out 'd07fb7a443b5db8a89d65a15a024af6a425615a5'\n",
"/content/decord\n",
"/content/decord/build\n",
"-- The C compiler identification is GNU 7.5.0\n",
"-- The CXX compiler identification is GNU 7.5.0\n",
"-- Detecting C compiler ABI info\n",
"-- Detecting C compiler ABI info - done\n",
"-- Check for working C compiler: /usr/bin/cc - skipped\n",
"-- Detecting C compile features\n",
"-- Detecting C compile features - done\n",
"-- Detecting CXX compiler ABI info\n",
"-- Detecting CXX compiler ABI info - done\n",
"-- Check for working CXX compiler: /usr/bin/c++ - skipped\n",
"-- Detecting CXX compile features\n",
"-- Detecting CXX compile features - done\n",
"-- Found PkgConfig: /usr/bin/pkg-config (found version \"0.29.1\") \n",
"-- Checking for module 'libavcodec'\n",
"-- Found libavcodec, version 57.107.100\n",
"-- Checking for module 'libavformat'\n",
"-- Found libavformat, version 57.83.100\n",
"-- Checking for module 'libavutil'\n",
"-- Found libavutil, version 55.78.100\n",
"-- Checking for module 'libavdevice'\n",
"-- No package 'libavdevice' found\n",
"-- Checking for module 'libavfilter'\n",
"-- Found libavfilter, version 6.107.100\n",
"-- Checking for module 'libswresample'\n",
"-- Found libswresample, version 2.9.100\n",
"-- Unable to find libavdevice, device input API will not work!\n",
"-- Found FFMPEG or Libav: /usr/lib/x86_64-linux-gnu/libavformat.so;/usr/lib/x86_64-linux-gnu/libavfilter.so;/usr/lib/x86_64-linux-gnu/libavcodec.so;/usr/lib/x86_64-linux-gnu/libavutil.so;/usr/lib/x86_64-linux-gnu/libswresample.so, /usr/include/x86_64-linux-gnu\n",
"-- The CUDA compiler identification is NVIDIA 11.1.105\n",
"-- Detecting CUDA compiler ABI info\n",
"-- Detecting CUDA compiler ABI info - done\n",
"-- Check for working CUDA compiler: /usr/local/cuda/bin/nvcc - skipped\n",
"-- Detecting CUDA compile features\n",
"-- Detecting CUDA compile features - done\n",
"-- Performing Test SUPPORT_CXX11\n",
"-- Performing Test SUPPORT_CXX11 - Success\n",
"\u001b[0mFFMPEG_INCLUDE_DIR = /usr/include/x86_64-linux-gnu \u001b[0m\n",
"\u001b[0mFFMPEG_LIBRARIES = /usr/lib/x86_64-linux-gnu/libavformat.so;/usr/lib/x86_64-linux-gnu/libavfilter.so;/usr/lib/x86_64-linux-gnu/libavcodec.so;/usr/lib/x86_64-linux-gnu/libavutil.so;/usr/lib/x86_64-linux-gnu/libswresample.so \u001b[0m\n",
"-- Looking for pthread.h\n",
"-- Looking for pthread.h - found\n",
"-- Performing Test CMAKE_HAVE_LIBC_PTHREAD\n",
"-- Performing Test CMAKE_HAVE_LIBC_PTHREAD - Failed\n",
"-- Looking for pthread_create in pthreads\n",
"-- Looking for pthread_create in pthreads - not found\n",
"-- Looking for pthread_create in pthread\n",
"-- Looking for pthread_create in pthread - found\n",
"-- Found Threads: TRUE \n",
"-- Found CUDA_TOOLKIT_ROOT_DIR=/usr/local/cuda\n",
"-- Found CUDA_CUDA_LIBRARY=/usr/local/cuda/targets/x86_64-linux/lib/stubs/libcuda.so\n",
"-- Found CUDA_CUDART_LIBRARY=/usr/local/cuda/lib64/libcudart.so\n",
"-- Found CUDA_NVRTC_LIBRARY=/usr/local/cuda/lib64/libnvrtc.so\n",
"-- Found CUDA_CUDNN_LIBRARY=/usr/lib/x86_64-linux-gnu/libcudnn.so\n",
"-- Found CUDA_CUBLAS_LIBRARY=/usr/lib/x86_64-linux-gnu/libcublas.so\n",
"-- Found CUDA_NVIDIA_ML_LIBRARY=/usr/local/cuda/targets/x86_64-linux/lib/stubs/libnvidia-ml.so\n",
"-- Found CUDA_NVCUVID_LIBRARY=/usr/lib/x86_64-linux-gnu/libnvcuvid.so\n",
"-- Build with CUDA support\n",
"-- Configuring done\n",
"\u001b[33mCMake Warning (dev) in CMakeLists.txt:\n",
" Policy CMP0104 is not set: CMAKE_CUDA_ARCHITECTURES now detected for NVCC,\n",
" empty CUDA_ARCHITECTURES not allowed. Run \"cmake --help-policy CMP0104\"\n",
" for policy details. Use the cmake_policy command to set the policy and\n",
" suppress this warning.\n",
"\n",
" CUDA_ARCHITECTURES is empty for target \"decord\".\n",
"This warning is for project developers. Use -Wno-dev to suppress it.\n",
"\u001b[0m\n",
"-- Generating done\n",
"-- Build files have been written to: /content/decord/build\n",
"[ 2%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/audio/audio_interface.cc.o\u001b[0m\n",
"[ 5%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/audio/audio_reader.cc.o\u001b[0m\n",
"[ 8%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/c_runtime_api.cc.o\u001b[0m\n",
"[ 10%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/cpu_device_api.cc.o\u001b[0m\n",
"[ 13%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/dso_module.cc.o\u001b[0m\n",
"[ 16%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/file_util.cc.o\u001b[0m\n",
"[ 18%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/module.cc.o\u001b[0m\n",
"[ 21%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/module_util.cc.o\u001b[0m\n",
"[ 24%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/ndarray.cc.o\u001b[0m\n",
"[ 27%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/registry.cc.o\u001b[0m\n",
"[ 29%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/str_util.cc.o\u001b[0m\n",
"[ 32%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/system_lib_module.cc.o\u001b[0m\n",
"[ 35%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/thread_pool.cc.o\u001b[0m\n",
"[ 37%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/threading_backend.cc.o\u001b[0m\n",
"[ 40%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/workspace_pool.cc.o\u001b[0m\n",
"[ 43%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/sampler/random_file_order_sampler.cc.o\u001b[0m\n",
"[ 45%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/sampler/random_sampler.cc.o\u001b[0m\n",
"[ 48%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/sampler/sequential_sampler.cc.o\u001b[0m\n",
"[ 51%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/sampler/smart_random_sampler.cc.o\u001b[0m\n",
"[ 54%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/logging.cc.o\u001b[0m\n",
"[ 56%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/storage_pool.cc.o\u001b[0m\n",
"[ 59%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/video_interface.cc.o\u001b[0m\n",
"[ 62%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/video_loader.cc.o\u001b[0m\n",
"[ 64%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/video_reader.cc.o\u001b[0m\n",
"[ 67%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/ffmpeg/filter_graph.cc.o\u001b[0m\n",
"[ 70%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/ffmpeg/threaded_decoder.cc.o\u001b[0m\n",
"[ 72%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_context.cc.o\u001b[0m\n",
"[ 75%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_decoder_impl.cc.o\u001b[0m\n",
"[ 78%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_mapped_frame.cc.o\u001b[0m\n",
"[ 81%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_parser.cc.o\u001b[0m\n",
"[ 83%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_stream.cc.o\u001b[0m\n",
"[ 86%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_texture.cc.o\u001b[0m\n",
"[ 89%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/video/nvcodec/cuda_threaded_decoder.cc.o\u001b[0m\n",
"[ 91%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/cuda/cuda_device_api.cc.o\u001b[0m\n",
"[ 94%] \u001b[32mBuilding CXX object CMakeFiles/decord.dir/src/runtime/cuda/cuda_module.cc.o\u001b[0m\n",
"[ 97%] \u001b[32mBuilding CUDA object CMakeFiles/decord.dir/src/improc/improc.cu.o\u001b[0m\n",
"[100%] \u001b[32m\u001b[1mLinking CXX shared library libdecord.so\u001b[0m\n",
"[100%] Built target decord\n",
"/content/decord/python\n",
"running install\n",
"running bdist_egg\n",
"running egg_info\n",
"creating decord.egg-info\n",
"writing decord.egg-info/PKG-INFO\n",
"writing dependency_links to decord.egg-info/dependency_links.txt\n",
"writing requirements to decord.egg-info/requires.txt\n",
"writing top-level names to decord.egg-info/top_level.txt\n",
"writing manifest file 'decord.egg-info/SOURCES.txt'\n",
"writing manifest file 'decord.egg-info/SOURCES.txt'\n",
"installing library code to build/bdist.linux-x86_64/egg\n",
"running install_lib\n",
"running build_py\n",
"creating build\n",
"creating build/lib\n",
"creating build/lib/decord\n",
"copying decord/__init__.py -> build/lib/decord\n",
"copying decord/audio_reader.py -> build/lib/decord\n",
"copying decord/av_reader.py -> build/lib/decord\n",
"copying decord/ndarray.py -> build/lib/decord\n",
"copying decord/video_reader.py -> build/lib/decord\n",
"copying decord/base.py -> build/lib/decord\n",
"copying decord/logging.py -> build/lib/decord\n",
"copying decord/video_loader.py -> build/lib/decord\n",
"copying decord/_api_internal.py -> build/lib/decord\n",
"creating build/lib/decord/function\n",
"copying decord/function/__init__.py -> build/lib/decord/function\n",
"copying decord/function/base.py -> build/lib/decord/function\n",
"creating build/lib/decord/data\n",
"copying decord/data/__init__.py -> build/lib/decord/data\n",
"copying decord/data/dataloader.py -> build/lib/decord/data\n",
"copying decord/data/base_action.py -> build/lib/decord/data\n",
"creating build/lib/decord/bridge\n",
"copying decord/bridge/__init__.py -> build/lib/decord/bridge\n",
"copying decord/bridge/torchdl.py -> build/lib/decord/bridge\n",
"copying decord/bridge/tvm.py -> build/lib/decord/bridge\n",
"copying decord/bridge/utils.py -> build/lib/decord/bridge\n",
"copying decord/bridge/mxnet.py -> build/lib/decord/bridge\n",
"copying decord/bridge/tf.py -> build/lib/decord/bridge\n",
"creating build/lib/decord/_ffi\n",
"copying decord/_ffi/function.py -> build/lib/decord/_ffi\n",
"copying decord/_ffi/runtime_ctypes.py -> build/lib/decord/_ffi\n",
"copying decord/_ffi/__init__.py -> build/lib/decord/_ffi\n",
"copying decord/_ffi/ndarray.py -> build/lib/decord/_ffi\n",
"copying decord/_ffi/libinfo.py -> build/lib/decord/_ffi\n",
"copying decord/_ffi/base.py -> build/lib/decord/_ffi\n",
"creating build/lib/decord/data/kinetics\n",
"copying decord/data/kinetics/__init__.py -> build/lib/decord/data/kinetics\n",
"copying decord/data/kinetics/kinetics400_action.py -> build/lib/decord/data/kinetics\n",
"creating build/lib/decord/data/transforms\n",
"copying decord/data/transforms/__init__.py -> build/lib/decord/data/transforms\n",
"copying decord/data/transforms/action.py -> build/lib/decord/data/transforms\n",
"creating build/lib/decord/_ffi/_cy2\n",
"copying decord/_ffi/_cy2/__init__.py -> build/lib/decord/_ffi/_cy2\n",
"creating build/lib/decord/_ffi/_ctypes\n",
"copying decord/_ffi/_ctypes/function.py -> build/lib/decord/_ffi/_ctypes\n",
"copying decord/_ffi/_ctypes/__init__.py -> build/lib/decord/_ffi/_ctypes\n",
"copying decord/_ffi/_ctypes/ndarray.py -> build/lib/decord/_ffi/_ctypes\n",
"copying decord/_ffi/_ctypes/types.py -> build/lib/decord/_ffi/_ctypes\n",
"creating build/lib/decord/_ffi/_cy3\n",
"copying decord/_ffi/_cy3/__init__.py -> build/lib/decord/_ffi/_cy3\n",
"copying decord/_ffi/README.md -> build/lib/decord/_ffi\n",
"creating build/lib/decord/_ffi/_cython\n",
"copying decord/_ffi/_cython/.gitignore -> build/lib/decord/_ffi/_cython\n",
"copying decord/_ffi/_cython/base.pxi -> build/lib/decord/_ffi/_cython\n",
"copying decord/_ffi/_cython/core.pyx -> build/lib/decord/_ffi/_cython\n",
"copying decord/_ffi/_cython/function.pxi -> build/lib/decord/_ffi/_cython\n",
"copying decord/_ffi/_cython/ndarray.pxi -> build/lib/decord/_ffi/_cython\n",
"copying decord/_ffi/_cython/node.pxi -> build/lib/decord/_ffi/_cython\n",
"running build_ext\n",
"creating build/bdist.linux-x86_64\n",
"creating build/bdist.linux-x86_64/egg\n",
"creating build/bdist.linux-x86_64/egg/decord\n",
"copying build/lib/decord/__init__.py -> build/bdist.linux-x86_64/egg/decord\n",
"creating build/bdist.linux-x86_64/egg/decord/function\n",
"copying build/lib/decord/function/__init__.py -> build/bdist.linux-x86_64/egg/decord/function\n",
"copying build/lib/decord/function/base.py -> build/bdist.linux-x86_64/egg/decord/function\n",
"copying build/lib/decord/audio_reader.py -> build/bdist.linux-x86_64/egg/decord\n",
"copying build/lib/decord/av_reader.py -> build/bdist.linux-x86_64/egg/decord\n",
"copying build/lib/decord/ndarray.py -> build/bdist.linux-x86_64/egg/decord\n",
"copying build/lib/decord/video_reader.py -> build/bdist.linux-x86_64/egg/decord\n",
"creating build/bdist.linux-x86_64/egg/decord/data\n",
"copying build/lib/decord/data/__init__.py -> build/bdist.linux-x86_64/egg/decord/data\n",
"copying build/lib/decord/data/dataloader.py -> build/bdist.linux-x86_64/egg/decord/data\n",
"copying build/lib/decord/data/base_action.py -> build/bdist.linux-x86_64/egg/decord/data\n",
"creating build/bdist.linux-x86_64/egg/decord/data/kinetics\n",
"copying build/lib/decord/data/kinetics/__init__.py -> build/bdist.linux-x86_64/egg/decord/data/kinetics\n",
"copying build/lib/decord/data/kinetics/kinetics400_action.py -> build/bdist.linux-x86_64/egg/decord/data/kinetics\n",
"creating build/bdist.linux-x86_64/egg/decord/data/transforms\n",
"copying build/lib/decord/data/transforms/__init__.py -> build/bdist.linux-x86_64/egg/decord/data/transforms\n",
"copying build/lib/decord/data/transforms/action.py -> build/bdist.linux-x86_64/egg/decord/data/transforms\n",
"creating build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/bridge/__init__.py -> build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/bridge/torchdl.py -> build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/bridge/tvm.py -> build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/bridge/utils.py -> build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/bridge/mxnet.py -> build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/bridge/tf.py -> build/bdist.linux-x86_64/egg/decord/bridge\n",
"copying build/lib/decord/base.py -> build/bdist.linux-x86_64/egg/decord\n",
"copying build/lib/decord/logging.py -> build/bdist.linux-x86_64/egg/decord\n",
"creating build/bdist.linux-x86_64/egg/decord/_ffi\n",
"copying build/lib/decord/_ffi/function.py -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"copying build/lib/decord/_ffi/runtime_ctypes.py -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"copying build/lib/decord/_ffi/__init__.py -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"copying build/lib/decord/_ffi/ndarray.py -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"copying build/lib/decord/_ffi/libinfo.py -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"creating build/bdist.linux-x86_64/egg/decord/_ffi/_cy2\n",
"copying build/lib/decord/_ffi/_cy2/__init__.py -> build/bdist.linux-x86_64/egg/decord/_ffi/_cy2\n",
"creating build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes\n",
"copying build/lib/decord/_ffi/_ctypes/function.py -> build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes\n",
"copying build/lib/decord/_ffi/_ctypes/__init__.py -> build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes\n",
"copying build/lib/decord/_ffi/_ctypes/ndarray.py -> build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes\n",
"copying build/lib/decord/_ffi/_ctypes/types.py -> build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes\n",
"copying build/lib/decord/_ffi/base.py -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"creating build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/_cython/base.pxi -> build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/_cython/node.pxi -> build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/_cython/ndarray.pxi -> build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/_cython/function.pxi -> build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/_cython/core.pyx -> build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/_cython/.gitignore -> build/bdist.linux-x86_64/egg/decord/_ffi/_cython\n",
"copying build/lib/decord/_ffi/README.md -> build/bdist.linux-x86_64/egg/decord/_ffi\n",
"creating build/bdist.linux-x86_64/egg/decord/_ffi/_cy3\n",
"copying build/lib/decord/_ffi/_cy3/__init__.py -> build/bdist.linux-x86_64/egg/decord/_ffi/_cy3\n",
"copying build/lib/decord/video_loader.py -> build/bdist.linux-x86_64/egg/decord\n",
"copying build/lib/decord/_api_internal.py -> build/bdist.linux-x86_64/egg/decord\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/function/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/function/base.py to base.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/audio_reader.py to audio_reader.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/av_reader.py to av_reader.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/ndarray.py to ndarray.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/video_reader.py to video_reader.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/dataloader.py to dataloader.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/base_action.py to base_action.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/kinetics/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/kinetics/kinetics400_action.py to kinetics400_action.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/transforms/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/data/transforms/action.py to action.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/bridge/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/bridge/torchdl.py to torchdl.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/bridge/tvm.py to tvm.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/bridge/utils.py to utils.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/bridge/mxnet.py to mxnet.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/bridge/tf.py to tf.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/base.py to base.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/logging.py to logging.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/function.py to function.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/runtime_ctypes.py to runtime_ctypes.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/ndarray.py to ndarray.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/libinfo.py to libinfo.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/_cy2/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes/function.py to function.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes/ndarray.py to ndarray.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/_ctypes/types.py to types.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/base.py to base.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_ffi/_cy3/__init__.py to __init__.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/video_loader.py to video_loader.cpython-37.pyc\n",
"byte-compiling build/bdist.linux-x86_64/egg/decord/_api_internal.py to _api_internal.cpython-37.pyc\n",
"installing package data to build/bdist.linux-x86_64/egg\n",
"running install_data\n",
"copying ../build/libdecord.so -> build/bdist.linux-x86_64/egg/decord\n",
"creating build/bdist.linux-x86_64/egg/EGG-INFO\n",
"copying decord.egg-info/PKG-INFO -> build/bdist.linux-x86_64/egg/EGG-INFO\n",
"copying decord.egg-info/SOURCES.txt -> build/bdist.linux-x86_64/egg/EGG-INFO\n",
"copying decord.egg-info/dependency_links.txt -> build/bdist.linux-x86_64/egg/EGG-INFO\n",
"copying decord.egg-info/not-zip-safe -> build/bdist.linux-x86_64/egg/EGG-INFO\n",
"copying decord.egg-info/requires.txt -> build/bdist.linux-x86_64/egg/EGG-INFO\n",
"copying decord.egg-info/top_level.txt -> build/bdist.linux-x86_64/egg/EGG-INFO\n",
"creating dist\n",
"creating 'dist/decord-0.6.0-py3.7-linux-x86_64.egg' and adding 'build/bdist.linux-x86_64/egg' to it\n",
"removing 'build/bdist.linux-x86_64/egg' (and everything under it)\n",
"Processing decord-0.6.0-py3.7-linux-x86_64.egg\n",
"creating /root/.local/lib/python3.7/site-packages/decord-0.6.0-py3.7-linux-x86_64.egg\n",
"Extracting decord-0.6.0-py3.7-linux-x86_64.egg to /root/.local/lib/python3.7/site-packages\n",
"Adding decord 0.6.0 to easy-install.pth file\n",
"\n",
"Installed /root/.local/lib/python3.7/site-packages/decord-0.6.0-py3.7-linux-x86_64.egg\n",
"Processing dependencies for decord==0.6.0\n",
"Searching for numpy==1.21.6\n",
"Best match: numpy 1.21.6\n",
"Adding numpy 1.21.6 to easy-install.pth file\n",
"Installing f2py script to /root/.local/bin\n",
"Installing f2py3 script to /root/.local/bin\n",
"Installing f2py3.7 script to /root/.local/bin\n",
"\n",
"Using /usr/local/lib/python3.7/dist-packages\n",
"Finished processing dependencies for decord==0.6.0\n",
"/content\n"
]
}
]
},
{
"cell_type": "markdown",
"source": [
"获取一些样例视频"
],
"metadata": {
"id": "g0NcyvNuW7gs"
}
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"id": "BPo1CIVsG3DB"
},
"outputs": [],
"source": [
"# 提前在Drive里准备好的一个视频 50M 30min\n",
"!cp ./drive/MyDrive/sample_videos/long.mp4 ."
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "2s8pQRYZIr93",
"outputId": "2d346604-7674-4180-eed5-08d038da976e"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"[youtube] jNQXAC9IVRw: Downloading webpage\n",
"[download] Destination: short.f133.mp4\n",
"\u001b[K[download] 100% of 200.32KiB in 00:03\n",
"[download] Destination: short.mp4.f140\n",
"\u001b[K[download] 100% of 301.95KiB in 00:04\n",
"[ffmpeg] Merging formats into \"short.mp4\"\n",
"Deleting original file short.f133.mp4 (pass -k to keep)\n",
"Deleting original file short.mp4.f140 (pass -k to keep)\n"
]
}
],
"source": [
"# 从youtube上下载一个短视频\n",
"!youtube-dl 'https://www.youtube.com/watch?v=jNQXAC9IVRw' -o short.mp4 -f 'bestvideo[ext=mp4]+bestaudio[ext=m4a]/best[ext=mp4]/best'"
]
},
{
"cell_type": "code",
"source": [
"# 从filesamples上下载一个4K视频 126M\n",
"!curl -O https://filesamples.com/samples/video/mp4/sample_3840x2160.mp4 # 126M 4k vid\n",
"!mv sample_3840x2160.mp4 big.mp4"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "b4qxV7iTq1ZK",
"outputId": "c7e2b6b3-3439-4fe6-a55f-cd07abb84d5b"
},
"execution_count": 6,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
" % Total % Received % Xferd Average Speed Time Time Time Current\n",
" Dload Upload Total Spent Left Speed\n",
"100 126M 0 126M 0 0 89.0M 0 --:--:-- 0:00:01 --:--:-- 89.0M\n"
]
}
]
},
{
"cell_type": "markdown",
"source": [
"## 内存使用分析\n",
"\n",
"+ `decord`的内存占用一般,不会把所有数据都载入,GPU版本和CPU版本在视频长度不同的情况下内存占用表现不一样。总体来说可以接受。\n",
"+ `mmcv`一导入就占据了很多内存(这个库重点不在读取视频,所以会加载很多其他的),初始化的时候不会占用很多内存,但是每读取一帧就增加一点内存?\n",
"+ `pyAV`和`OpenCV`差不多,内存使用不多"
],
"metadata": {
"id": "Tu3zzFXDW-gI"
}
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "pKcgK6D4Kys_",
"outputId": "0ce271a0-9f98-4931-8f45-9b9a6544d80d"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Filename: tmp.py\n",
"\n",
"Line # Mem usage Increment Occurrences Line Contents\n",
"=============================================================\n",
" 4 76.219 MiB 76.219 MiB 1 @profile\n",
" 5 def my_func():\n",
" 6 107.246 MiB 31.027 MiB 1 vr = VideoReader('big.mp4', ctx=cpu(0))\n",
" 7 369.172 MiB 261.926 MiB 1 img = vr[0]\n",
" 8 421.359 MiB 52.188 MiB 1 img = vr[1]\n",
" 9 421.359 MiB 0.000 MiB 1 img = vr[2]\n",
" 10 425.477 MiB 4.117 MiB 1 img = vr[3]\n",
" 11 425.477 MiB 0.000 MiB 1 img = vr[4]\n",
" 12 437.328 MiB 11.852 MiB 1 img = vr[5]\n",
" 13 437.328 MiB 0.000 MiB 1 img = vr[6]\n",
" 14 438.352 MiB 1.023 MiB 1 img = vr[7]\n",
" 15 438.352 MiB 0.000 MiB 1 img = vr[8]\n",
" 16 438.352 MiB 0.000 MiB 1 img = vr[9]\n",
"\n",
"\n",
"CPU times: user 13.2 ms, sys: 30.3 ms, total: 43.5 ms\n",
"Wall time: 1.66 s\n"
]
}
],
"source": [
"code = \"\"\"\n",
"from decord import VideoReader\n",
"from decord import cpu\n",
"@profile\n",
"def my_func():\n",
" vr = VideoReader('big.mp4', ctx=cpu(0))\n",
" img = vr[0]\n",
" img = vr[1]\n",
" img = vr[2]\n",
" img = vr[3]\n",
" img = vr[4]\n",
" img = vr[5]\n",
" img = vr[6]\n",
" img = vr[7]\n",
" img = vr[8]\n",
" img = vr[9]\n",
"\n",
"if __name__ == '__main__':\n",
" my_func()\n",
"\"\"\"\n",
"with open(\"tmp.py\", \"w+\") as f:\n",
" f.write(code)\n",
"%time !python -m memory_profiler tmp.py"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"outputId": "9983ce8c-fdee-4313-8024-56fbfa7661ba",
"id": "SfxIAFYYu_Un"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Filename: tmp.py\n",
"\n",
"Line # Mem usage Increment Occurrences Line Contents\n",
"=============================================================\n",
" 4 76.250 MiB 76.250 MiB 1 @profile\n",
" 5 def my_func():\n",
" 6 198.934 MiB 122.684 MiB 1 vr = VideoReader('big.mp4', ctx=gpu(0))\n",
" 7 263.465 MiB 64.531 MiB 1 img = vr[0]\n",
" 8 263.465 MiB 0.000 MiB 1 img = vr[1]\n",
" 9 263.465 MiB 0.000 MiB 1 img = vr[2]\n",
" 10 263.465 MiB 0.000 MiB 1 img = vr[3]\n",
" 11 263.465 MiB 0.000 MiB 1 img = vr[4]\n",
" 12 263.465 MiB 0.000 MiB 1 img = vr[5]\n",
" 13 263.465 MiB 0.000 MiB 1 img = vr[6]\n",
" 14 263.465 MiB 0.000 MiB 1 img = vr[7]\n",
" 15 263.465 MiB 0.000 MiB 1 img = vr[8]\n",
" 16 263.465 MiB 0.000 MiB 1 img = vr[9]\n",
"\n",
"\n",
"CPU times: user 14.2 ms, sys: 34.4 ms, total: 48.6 ms\n",
"Wall time: 1.16 s\n"
]
}
],
"source": [
"code = \"\"\"\n",
"from decord import VideoReader\n",
"from decord import gpu\n",
"@profile\n",
"def my_func():\n",
" vr = VideoReader('big.mp4', ctx=gpu(0))\n",
" img = vr[0]\n",
" img = vr[1]\n",
" img = vr[2]\n",
" img = vr[3]\n",
" img = vr[4]\n",
" img = vr[5]\n",
" img = vr[6]\n",
" img = vr[7]\n",
" img = vr[8]\n",
" img = vr[9]\n",
"\n",
"if __name__ == '__main__':\n",
" my_func()\n",
"\"\"\"\n",
"with open(\"tmp.py\", \"w+\") as f:\n",
" f.write(code)\n",
"%time !python -m memory_profiler tmp.py"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "KuNbH-OMVHOY",
"outputId": "7c1c8043-f6c2-41f0-cf78-711c1890e544"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Filename: tmp.py\n",
"\n",
"Line # Mem usage Increment Occurrences Line Contents\n",
"=============================================================\n",
" 3 281.496 MiB 281.496 MiB 1 @profile\n",
" 4 def my_func():\n",
" 5 308.559 MiB 27.062 MiB 1 v = VideoReader('big.mp4')\n",
" 6 411.469 MiB 102.910 MiB 1 img = next(v)\n",
" 7 451.512 MiB 40.043 MiB 1 img = next(v)\n",
" 8 479.375 MiB 27.863 MiB 1 img = next(v)\n",
" 9 503.137 MiB 23.762 MiB 1 img = next(v)\n",
" 10 526.883 MiB 23.746 MiB 1 img = next(v)\n",
" 11 562.488 MiB 35.605 MiB 1 img = next(v)\n",
" 12 586.500 MiB 24.012 MiB 1 img = next(v)\n",
" 13 610.258 MiB 23.758 MiB 1 img = next(v)\n",
" 14 638.711 MiB 28.453 MiB 1 img = next(v)\n",
" 15 662.793 MiB 24.082 MiB 1 img = next(v)\n",
"\n",
"\n",
"CPU times: user 27 ms, sys: 25.4 ms, total: 52.4 ms\n",
"Wall time: 2.86 s\n"
]
}
],
"source": [
"code = \"\"\"\n",
"from mmcv import VideoReader\n",
"@profile\n",
"def my_func():\n",
" v = VideoReader('big.mp4')\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
" img = next(v)\n",
"\n",
"if __name__ == '__main__':\n",
" my_func()\n",
"\"\"\"\n",
"with open(\"tmp.py\", \"w+\") as f:\n",
" f.write(code)\n",
"%time !python -m memory_profiler tmp.py"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "xwAh-RAHV57N",
"outputId": "17dd0271-78ad-4f01-e05f-f3b4b1587ff7"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Filename: tmp.py\n",
"\n",
"Line # Mem usage Increment Occurrences Line Contents\n",
"=============================================================\n",
" 3 76.363 MiB 76.363 MiB 1 @profile\n",
" 4 def my_func():\n",
" 5 104.723 MiB 28.359 MiB 1 cap = cv2.VideoCapture(\"big.mp4\")\n",
" 6 208.176 MiB 103.453 MiB 1 frame_exists, rgb = cap.read()\n",
" 7 247.961 MiB 39.785 MiB 1 frame_exists, rgb = cap.read()\n",
" 8 271.719 MiB 23.758 MiB 1 frame_exists, rgb = cap.read()\n",
" 9 271.719 MiB 0.000 MiB 1 frame_exists, rgb = cap.read()\n",
" 10 271.719 MiB 0.000 MiB 1 frame_exists, rgb = cap.read()\n",
" 11 271.719 MiB 0.000 MiB 1 frame_exists, rgb = cap.read()\n",
" 12 271.719 MiB 0.000 MiB 1 frame_exists, rgb = cap.read()\n",
" 13 271.719 MiB 0.000 MiB 1 frame_exists, rgb = cap.read()\n",
" 14 271.719 MiB 0.000 MiB 1 frame_exists, rgb = cap.read()\n",
" 15 271.969 MiB 0.250 MiB 1 frame_exists, rgb = cap.read()\n",
"\n",
"\n",
"CPU times: user 12.1 ms, sys: 32.3 ms, total: 44.4 ms\n",
"Wall time: 1.46 s\n"
]
}
],
"source": [
"code = \"\"\"\n",
"import cv2\n",
"@profile\n",
"def my_func():\n",
" cap = cv2.VideoCapture(\"big.mp4\")\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
" frame_exists, rgb = cap.read()\n",
"\n",
"if __name__ == '__main__':\n",
" my_func()\n",
"\"\"\"\n",
"with open(\"tmp.py\", \"w+\") as f:\n",
" f.write(code)\n",
"%time !python -m memory_profiler tmp.py"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"outputId": "ceaed6d9-1c17-4501-e295-7419f82db73f",
"id": "gejDzyu9r608"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Filename: tmp.py\n",
"\n",
"Line # Mem usage Increment Occurrences Line Contents\n",
"=============================================================\n",
" 4 55.141 MiB 55.141 MiB 1 @profile\n",
" 5 def my_func():\n",
" 6 81.105 MiB 25.965 MiB 1 with av.open(\"big.mp4\") as container:\n",
" 7 81.105 MiB 0.000 MiB 1 stream = container.streams.video[0]\n",
" 8 81.105 MiB 0.000 MiB 1 decoder = container.decode(stream)\n",
" 9 151.891 MiB 70.785 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 10 192.848 MiB 40.957 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 11 216.438 MiB 23.590 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 12 216.672 MiB 0.234 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 13 216.688 MiB 0.016 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 14 216.688 MiB 0.000 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 15 216.695 MiB 0.008 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 16 216.695 MiB 0.000 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 17 216.695 MiB 0.000 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" 18 216.703 MiB 0.008 MiB 1 array = next(decoder).to_ndarray(format=\"rgb24\")\n",
"\n",
"\n"
]
}
],
"source": [
"code = \"\"\"\n",
"import av\n",
"\n",
"@profile\n",
"def my_func():\n",
" with av.open(\"big.mp4\") as container:\n",
" stream = container.streams.video[0]\n",
" decoder = container.decode(stream)\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
" array = next(decoder).to_ndarray(format=\"rgb24\")\n",
"if __name__ == '__main__':\n",
" my_func()\n",
"\"\"\"\n",
"with open(\"tmp.py\", \"w+\") as f:\n",
" f.write(code)\n",
"!python -m memory_profiler tmp.py"
]
},
{
"cell_type": "markdown",
"source": [
"## 接口比较\n",
"\n",
"每个方法都实现顺序读取视频和随机读取视频。\n",
"\n",
"+ `decord`和`mmcv`提供的接口很方便,面向对象,基本没有什么门槛。\n",
"+ `OpenCV`提供的接口没有那么方便,和c更接近一些,获取一些属性要先翻文档,\n",
"+ `pyAV`太底层了,是ffmpeg的python包装,更擅长处理不同格式视频流,不是很方便。由于其seek方法是基于时间的,没有找到基于帧序号的……"
],
"metadata": {
"id": "-ZQsW1QP8aPl"
}
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"id": "O1D5SFpNu2eU"
},
"outputs": [],
"source": [
"import decord\n",
"import mmcv\n",
"import cv2\n",
"import time\n",
"import random\n",
"from tqdm import tqdm\n",
"from decord import cpu, gpu\n",
"import av\n",
"def seq_read_decord(path, use_tqdm=True):\n",
" vr = decord.VideoReader(path, ctx=cpu(0))\n",
" for i in tqdm(range(len(vr)), disable=not use_tqdm):\n",
" img = vr[i]\n",
"def random_read_decord(path, random_num=100, use_tqdm=True):\n",
" vr = decord.VideoReader(path, ctx=cpu(0))\n",
" vl = len(vr)\n",
" for _ in tqdm(range(random_num), disable=not use_tqdm):\n",
" i = random.randrange(0, vl)\n",
" frame = vr[i]\n",
"\n",
"def seq_read_decord_gpu(path, use_tqdm=True):\n",
" vr = decord.VideoReader(path, ctx=gpu(0))\n",
" for i in tqdm(range(len(vr)), disable=not use_tqdm):\n",
" img = vr[i]\n",
"def random_read_decord_gpu(path, random_num=100, use_tqdm=True):\n",
" vr = decord.VideoReader(path, ctx=gpu(0))\n",
" vl = len(vr)\n",
" for _ in tqdm(range(random_num), disable=not use_tqdm):\n",
" i = random.randrange(0, vl)\n",
" frame = vr[i]\n",
"\n",
"def seq_read_mmcv(path, use_tqdm=True):\n",
" vr = mmcv.VideoReader(path)\n",
" for img in tqdm(vr, disable=not use_tqdm):\n",
" frame = img\n",
"def random_read_mmcv(path, random_num=100, use_tqdm=True):\n",
" vr = mmcv.VideoReader(path)\n",
" vl = len(vr)\n",
" for _ in tqdm(range(random_num), disable=not use_tqdm):\n",
" i = random.randrange(0, vl)\n",
" frame = vr[i]\n",
"\n",
"def seq_read_cv2(path, use_tqdm=True):\n",
" cap = cv2.VideoCapture(path)\n",
" pbar = tqdm(total=cap.get(cv2.CAP_PROP_FRAME_COUNT), disable=not use_tqdm)\n",
" while cap.isOpened():\n",
" frame_exists, rgb = cap.read()\n",
" pbar.update(1)\n",
" if frame_exists:\n",
" rgb = cv2.cvtColor(rgb, cv2.COLOR_BGR2RGB) # we need rgb numpy\n",
" else:\n",
" cap.release()\n",
" pbar.close()\n",
" break\n",
"def random_read_cv2(path, random_num=100, use_tqdm=True):\n",
" cap = cv2.VideoCapture(path)\n",
" vl = cap.get(cv2.CAP_PROP_FRAME_COUNT)\n",
" for _ in tqdm(range(random_num), disable=not use_tqdm):\n",
" i = random.randrange(0, vl)\n",
" cap.set(cv2.CAP_PROP_POS_FRAMES, i)\n",
" frame_exists, rgb = cap.read()\n",
" if frame_exists:\n",
" rgb = cv2.cvtColor(rgb, cv2.COLOR_BGR2RGB)\n",
" else:\n",
" cap.release()\n",
" break\n",
"\n",
"def seq_read_av(path, use_tqdm=True):\n",
" with av.open(path) as container:\n",
" stream = container.streams.video[0]\n",
" for frame in tqdm(container.decode(stream), disable=not use_tqdm):\n",
" array = frame.to_ndarray(format=\"rgb24\")\n",
" # print(type(array), array.dtype, array.shape)\n",
"\n",
"def random_read_av(path, random_num=100, use_tqdm=True):\n",
" # 要获取特定的第n帧太难了……\n",
" pass\n"
]
},
{
"cell_type": "markdown",
"source": [
"## 进行速度测试\n",
"\n",
"`OpenCV`在各方面表现都不错,可以作为一个基准进行比较。\n",
"\n",
"`decord`的GPU版本可能是在读取视频的时候要用GPU初始化,比较耗时,所以处理短视频较慢,而在长视频和4K视频中比其他方法强很多。其CPU版本比`OpenCV`略差一些。\n",
"\n",
"`mmcv`和`OpenCV`基本一致,在长视频和4K视频的顺序读取略强,在4K视频的随机读取略弱。\n",
"\n",
"`pyAV`在测试中没有表现出特点,结果都是较慢。\n",
"\n",
"> 由于时间原因,可能比较不是特别全面,多次运行可能会得到不同的结果,但是比较明显的结论不会改变:GPU版本的decord在处理数据量更大的视频时优势很明显。\n",
"\n",
"![临时算IO榜单_00.png]()"
],
"metadata": {
"id": "CfPLa5oE921n"
}
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"id": "-DdP0tMYwYdB"
},
"outputs": [],
"source": [
"def seq_read(func, path, repeat, use_tqdm=True):\n",
" start_time = time.time()\n",
" for _ in range(repeat):\n",
" func(path, use_tqdm=use_tqdm)\n",
" end_time = time.time()\n",
" return end_time - start_time\n",
"def random_read(func, path, repeat, random_num, use_tqdm=True):\n",
" start_time = time.time()\n",
" for _ in range(repeat):\n",
" func(path, random_num, use_tqdm=use_tqdm)\n",
" end_time = time.time()\n",
" return end_time - start_time"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "rG1e_z5fz-dv",
"outputId": "1da3281d-2df3-4d27-d94b-d6614548ff8f"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"For short video: \n",
"Sequential Read[100x]:\n",
"Decord GPU: 19.576740026474\n",
"Decord: 14.319761991500854\n",
"MMCV: 11.701236248016357\n",
"OpenCV: 11.556411266326904\n",
"PyAV: 17.922401189804077\n",
"Random Read[1x]:\n"
]
}
],
"source": [
"seq_repeat = 100\n",
"path = \"short.mp4\"\n",
"print(f\"For short video: \")\n",
"print(f\"Sequential Read[{seq_repeat}x]:\")\n",
"print(f\"Decord GPU: {seq_read(seq_read_decord_gpu, path, seq_repeat, use_tqdm=False)}\")\n",
"print(f\"Decord: {seq_read(seq_read_decord, path, seq_repeat, use_tqdm=False)}\")\n",
"print(f\"MMCV: {seq_read(seq_read_mmcv, path, seq_repeat, use_tqdm=False)}\")\n",
"print(f\"OpenCV: {seq_read(seq_read_cv2, path, seq_repeat, use_tqdm=False)}\")\n",
"print(f\"PyAV: {seq_read(seq_read_av, path, seq_repeat, use_tqdm=False)}\")"
]
},
{
"cell_type": "code",
"source": [
"path = \"short.mp4\"\n",
"random_repeat = 1\n",
"random_num = 100\n",
"print(f\"Random Read[{random_repeat}x]:\")\n",
"print(f\"Decord GPU: {random_read(random_read_decord_gpu, path, random_repeat, random_num, use_tqdm=False)}\")\n",
"print(f\"Decord: {random_read(random_read_decord, path, random_repeat, random_num, use_tqdm=False)}\")\n",
"print(f\"MMCV: {random_read(random_read_mmcv, path, random_repeat, random_num, use_tqdm=False)}\")\n",
"print(f\"OpenCV: {random_read(random_read_cv2, path, random_repeat, random_num, use_tqdm=False)}\")"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "97Y6UaXYe6pV",
"outputId": "bb893fa8-6b9f-4c69-8aec-a6992231e24a"
},
"execution_count": 7,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Random Read[1x]:\n",
"Decord GPU: 5.913957834243774\n",
"Decord: 1.5877439975738525\n",
"MMCV: 1.6674537658691406\n",
"OpenCV: 1.8470497131347656\n"
]
}
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "JR5XFOCEz_sh",
"outputId": "4233be5d-50e3-49bc-df3d-4e35a64cb972"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"For long video: \n",
"Sequential Read[1x]:\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 45000/45000 [01:13<00:00, 614.93it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord GPU: 73.3991289138794\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 45000/45000 [04:22<00:00, 171.58it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord: 262.47067618370056\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|█████████▉| 44998/45000 [03:33<00:00, 210.65it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"MMCV: 213.643714427948\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|█████████▉| 44999/45000.0 [04:15<00:00, 175.97it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"OpenCV: 255.74768257141113\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"44998it [03:46, 198.68it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"PyAV: 226.53186297416687\n",
"Random Read[5x]:\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 100/100 [00:18<00:00, 5.52it/s]\n",
"100%|██████████| 100/100 [00:17<00:00, 5.59it/s]\n",
"100%|██████████| 100/100 [00:16<00:00, 6.02it/s]\n",
"100%|██████████| 100/100 [00:18<00:00, 5.40it/s]\n",
"100%|██████████| 100/100 [00:18<00:00, 5.32it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord GPU: 90.98765110969543\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 100/100 [00:41<00:00, 2.39it/s]\n",
"100%|██████████| 100/100 [00:41<00:00, 2.42it/s]\n",
"100%|██████████| 100/100 [00:41<00:00, 2.39it/s]\n",
"100%|██████████| 100/100 [00:44<00:00, 2.22it/s]\n",
"100%|██████████| 100/100 [00:41<00:00, 2.39it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord: 212.76363229751587\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 100/100 [00:34<00:00, 2.92it/s]\n",
"100%|██████████| 100/100 [00:34<00:00, 2.88it/s]\n",
"100%|██████████| 100/100 [00:37<00:00, 2.64it/s]\n",
"100%|██████████| 100/100 [00:36<00:00, 2.73it/s]\n",
"100%|██████████| 100/100 [00:34<00:00, 2.91it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"MMCV: 178.0106749534607\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 100/100 [00:34<00:00, 2.90it/s]\n",
"100%|██████████| 100/100 [00:33<00:00, 2.96it/s]\n",
"100%|██████████| 100/100 [00:33<00:00, 3.00it/s]\n",
"100%|██████████| 100/100 [00:35<00:00, 2.81it/s]\n",
"100%|██████████| 100/100 [00:37<00:00, 2.63it/s]"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"OpenCV: 175.26724076271057\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"\n"
]
}
],
"source": [
"seq_repeat = 1\n",
"random_repeat = 5\n",
"random_num = 100\n",
"path = \"long.mp4\"\n",
"print(f\"For long video: \")\n",
"print(f\"Sequential Read[{seq_repeat}x]:\")\n",
"print(f\"Decord GPU: {seq_read(seq_read_decord_gpu, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"Decord: {seq_read(seq_read_decord, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"MMCV: {seq_read(seq_read_mmcv, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"OpenCV: {seq_read(seq_read_cv2, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"PyAV: {seq_read(seq_read_av, path, seq_repeat, use_tqdm=True)}\")\n",
"\n",
"print(f\"Random Read[{random_repeat}x]:\")\n",
"print(f\"Decord GPU: {random_read(random_read_decord_gpu, path, random_repeat, random_num, use_tqdm=True)}\")\n",
"print(f\"Decord: {random_read(random_read_decord, path, random_repeat, random_num, use_tqdm=True)}\")\n",
"print(f\"MMCV: {random_read(random_read_mmcv, path, random_repeat, random_num, use_tqdm=True)}\")\n",
"print(f\"OpenCV: {random_read(random_read_cv2, path, random_repeat, random_num, use_tqdm=True)}\")"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 991
},
"outputId": "5cfbeae0-858a-4df6-bb52-81068752deff",
"id": "cDlitQxS_RDn"
},
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"For big video: \n",
"Sequential Read[5x]:\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 677/677 [00:04<00:00, 155.42it/s]\n",
"100%|██████████| 677/677 [00:04<00:00, 162.28it/s]\n",
"100%|██████████| 677/677 [00:04<00:00, 165.06it/s]\n",
"100%|██████████| 677/677 [00:04<00:00, 160.76it/s]\n",
"100%|██████████| 677/677 [00:04<00:00, 161.86it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord GPU: 22.91811966896057\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 677/677 [00:41<00:00, 16.45it/s]\n",
"100%|██████████| 677/677 [00:37<00:00, 18.08it/s]\n",
"100%|██████████| 677/677 [00:37<00:00, 18.22it/s]\n",
"100%|██████████| 677/677 [00:38<00:00, 17.36it/s]\n",
"100%|██████████| 677/677 [00:36<00:00, 18.37it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord: 192.9010877609253\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 677/677 [00:35<00:00, 19.27it/s]\n",
"100%|██████████| 677/677 [00:34<00:00, 19.46it/s]\n",
"100%|██████████| 677/677 [00:36<00:00, 18.55it/s]\n",
"100%|██████████| 677/677 [00:34<00:00, 19.42it/s]\n",
"100%|██████████| 677/677 [00:34<00:00, 19.45it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"MMCV: 176.829448223114\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"678it [00:38, 17.81it/s] \n",
"678it [00:39, 17.19it/s] \n",
"678it [00:37, 17.86it/s] \n",
"678it [00:37, 17.85it/s] \n",
"678it [00:39, 17.11it/s] \n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"OpenCV: 193.79467034339905\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"677it [00:39, 17.21it/s]\n",
"677it [00:39, 17.23it/s]\n",
"677it [00:41, 16.46it/s]\n",
"677it [00:39, 17.01it/s]\n",
"677it [00:40, 16.89it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"PyAV: 200.42598056793213\n",
"Random Read[5x]:\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
" 28%|██▊ | 28/100 [00:19<00:48, 1.47it/s]\n"
]
},
{
"output_type": "error",
"ename": "DECORDError",
"evalue": "ignored",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
"\u001b[0;31mDECORDError\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m<ipython-input-8-54aa6a942424>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 12\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 13\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Random Read[{random_repeat}x]:\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 14\u001b[0;31m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Decord GPU: {random_read(random_read_decord_gpu, path, random_repeat, random_num, use_tqdm=True)}\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 15\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Decord: {random_read(random_read_decord, path, random_repeat, random_num, use_tqdm=True)}\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 16\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"MMCV: {random_read(random_read_mmcv, path, random_repeat, random_num, use_tqdm=True)}\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m<ipython-input-2-976d9979c9a7>\u001b[0m in \u001b[0;36mrandom_read\u001b[0;34m(func, path, repeat, random_num, use_tqdm)\u001b[0m\n\u001b[1;32m 8\u001b[0m \u001b[0mstart_time\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtime\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtime\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 9\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0m_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrepeat\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpath\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrandom_num\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0muse_tqdm\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0muse_tqdm\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 11\u001b[0m \u001b[0mend_time\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtime\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtime\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 12\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mend_time\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mstart_time\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m<ipython-input-1-f86f577dfcde>\u001b[0m in \u001b[0;36mrandom_read_decord_gpu\u001b[0;34m(path, random_num, use_tqdm)\u001b[0m\n\u001b[1;32m 27\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0m_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mtqdm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrandom_num\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdisable\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mnot\u001b[0m \u001b[0muse_tqdm\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 28\u001b[0m \u001b[0mi\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvl\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 29\u001b[0;31m \u001b[0mframe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mvr\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 30\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 31\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mseq_read_mmcv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mpath\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0muse_tqdm\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.local/lib/python3.7/site-packages/decord-0.6.0-py3.7-linux-x86_64.egg/decord/video_reader.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, idx)\u001b[0m\n\u001b[1;32m 103\u001b[0m \u001b[0;32mraise\u001b[0m \u001b[0mIndexError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Index: {} out of bound: {}\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_frame\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 104\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mseek_accurate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 105\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnext\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 106\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 107\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mnext\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.local/lib/python3.7/site-packages/decord-0.6.0-py3.7-linux-x86_64.egg/decord/video_reader.py\u001b[0m in \u001b[0;36mnext\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m 115\u001b[0m \"\"\"\n\u001b[1;32m 116\u001b[0m \u001b[0;32massert\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_handle\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 117\u001b[0;31m \u001b[0marr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_CAPI_VideoReaderNextFrame\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_handle\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 118\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0marr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 119\u001b[0m \u001b[0;32mraise\u001b[0m \u001b[0mStopIteration\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.local/lib/python3.7/site-packages/decord-0.6.0-py3.7-linux-x86_64.egg/decord/_ffi/_ctypes/function.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args)\u001b[0m\n\u001b[1;32m 173\u001b[0m check_call(_LIB.DECORDFuncCall(\n\u001b[1;32m 174\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvalues\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtcodes\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mctypes\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mc_int\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnum_args\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 175\u001b[0;31m ctypes.byref(ret_val), ctypes.byref(ret_tcode)))\n\u001b[0m\u001b[1;32m 176\u001b[0m \u001b[0m_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtemp_args\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 177\u001b[0m \u001b[0m_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/.local/lib/python3.7/site-packages/decord-0.6.0-py3.7-linux-x86_64.egg/decord/_ffi/base.py\u001b[0m in \u001b[0;36mcheck_call\u001b[0;34m(ret)\u001b[0m\n\u001b[1;32m 76\u001b[0m \u001b[0merr_str\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0merr_str\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msplit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'Stack trace'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstrip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 77\u001b[0m \u001b[0;32mraise\u001b[0m \u001b[0mDECORDLimitReachedError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0merr_str\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 78\u001b[0;31m \u001b[0;32mraise\u001b[0m \u001b[0mDECORDError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0merr_str\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 79\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 80\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;31mDECORDError\u001b[0m: [11:33:47] /content/decord/src/video/video_reader.cc:444: [big.mp4]Unable to handle EOF because it takes too long to retrieve last few frames and `DECORD_EOF_RETRY_MAX=10240`. You may override the limit by `export DECORD_EOF_RETRY_MAX=20480` for example to allow more EOF retry attempts, exit..."
]
}
],
"source": [
"seq_repeat = 5\n",
"random_repeat = 1\n",
"random_num = 100\n",
"path = \"big.mp4\"\n",
"print(f\"For big video: \")\n",
"print(f\"Sequential Read[{seq_repeat}x]:\")\n",
"print(f\"Decord GPU: {seq_read(seq_read_decord_gpu, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"Decord: {seq_read(seq_read_decord, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"MMCV: {seq_read(seq_read_mmcv, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"OpenCV: {seq_read(seq_read_cv2, path, seq_repeat, use_tqdm=True)}\")\n",
"print(f\"PyAV: {seq_read(seq_read_av, path, seq_repeat, use_tqdm=True)}\")"
]
},
{
"cell_type": "code",
"source": [
"import os\n",
"os.environ['DECORD_EOF_RETRY_MAX'] = \"20480\"\n",
"random_repeat = 1\n",
"random_num = 20\n",
"path = \"big.mp4\"\n",
"print(f\"Random Read[{random_repeat}x]:\")\n",
"print(f\"Decord GPU: {random_read(random_read_decord_gpu, path, random_repeat, random_num, use_tqdm=True)}\")\n",
"print(f\"Decord: {random_read(random_read_decord, path, random_repeat, random_num, use_tqdm=True)}\")\n",
"print(f\"MMCV: {random_read(random_read_mmcv, path, random_repeat, random_num, use_tqdm=True)}\")\n",
"print(f\"OpenCV: {random_read(random_read_cv2, path, random_repeat, random_num, use_tqdm=True)}\")"
],
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "0hiaQ2y1h4tZ",
"outputId": "64547c42-be3a-4f73-bcc7-0ef43e861fde"
},
"execution_count": 8,
"outputs": [
{
"output_type": "stream",
"name": "stdout",
"text": [
"Random Read[1x]:\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 20/20 [00:11<00:00, 1.74it/s]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord GPU: 12.417755365371704\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 20/20 [01:22<00:00, 4.12s/it]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"Decord: 82.7718915939331\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 20/20 [02:02<00:00, 6.13s/it]\n"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"MMCV: 122.92250633239746\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"100%|██████████| 20/20 [01:45<00:00, 5.28s/it]"
]
},
{
"output_type": "stream",
"name": "stdout",
"text": [
"OpenCV: 105.77272725105286\n"
]
},
{
"output_type": "stream",
"name": "stderr",
"text": [
"\n"
]
}
]
},
{
"cell_type": "markdown",
"source": [
"## Bug分析\n",
"\n",
"Decord有的时候会遇到奇奇怪怪的bug(如上),尤其是GPU版本。"
],
"metadata": {
"id": "xewGJujBkcSY"
}
},
{
"cell_type": "markdown",
"source": [
"## 总结\n",
"\n",
"假如要高效处理数据量大的视频,选用`Decord`的GPU版本。假如项目中其他地方会用到`mmcv`,那就用mmcv的VideoReader。其他情况假如想代码更易懂,则使用`Decord`,否则使用`OpenCV`。"
],
"metadata": {
"id": "X7F_7dDAmqxo"
}
},
{
"cell_type": "code",
"source": [],
"metadata": {
"id": "QmaRCGRLeih8"
},
"execution_count": null,
"outputs": []
}
],
"metadata": {
"colab": {
"collapsed_sections": [],
"name": "Benchmark of Video Reader in Python.ipynb",
"provenance": []
},
"kernelspec": {
"display_name": "Python 3",
"name": "python3"
},
"language_info": {
"name": "python"
},
"accelerator": "GPU",
"gpuClass": "standard"
},
"nbformat": 4,
"nbformat_minor": 0
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment