Skip to main content

PyNVVL: A Python wrapper for NVIDIA Video Loader (NVVL) with CuPy

Project description

PyNVVL

pypi-pynvvl-cuda80 pypi-pynvvl-cuda90 pypi-pynvvl-cuda91 GitHub license

PyNVVL is a thin wrapper of NVIDIA Video Loader (NVVL). This package enables you to load videos directoly to GPU memory and access them as CuPy ndarrays with zero copy. The pre-built binaries of PyNVVL include NVVL itself, so you do not need to install NVVL.

Requirements

  • CUDA 8.0, 9.0, or 9.1
  • Python 2.7.6+, 3.4.7+, 3.5.1+, or 3.6.0+
  • CuPy v4.0.0

Tested Environment

  • Ubuntu 16.04
  • Python 2.7.6+, 3.4.7+, 3.5.1+, and 3.6.0+
  • CUDA 8.0, 9.0, and 9.1

Install the pre-built binary

Please choose a right package depending on your CUDA version.

# [For CUDA 8.0]
pip install pynvvl-cuda80

# [For CUDA 9.0]
pip install pynvvl-cuda90

# [For CUDA 9.1]
pip install pynvvl-cuda91

Usage

import pynvvl
import matplotlib.pyplot as plt

# Create NVVLVideoLoader object
loader = pynvvl.NVVLVideoLoader(device_id=0, log_level='error')

# Show the number of frames in the video
n_frames = loader.frame_count('examples/sample.mp4')
print('Number of frames:', n_frames)

# Load a video and return it as a CuPy array
video = loader.read_sequence(
    'examples/sample.mp4',
    horiz_flip=True,
    scale_height=512,
    scale_width=512,
    crop_y=60,
    crop_height=385,
    crop_width=512,
    scale_method='Linear',
    normalized=True
)

print(video.shape)  # => (91, 3, 385, 512): (n_frames, channels, height, width)
print(video.dtype)  # => float32

# Get the first frame as numpy array
frame = video[0].get()
frame = frame.transpose(1, 2, 0)

plt.imshow(frame)
plt.savefig('examples/sample.png')

This video is flickr-2-6-3-3-5-2-7-6-5626335276_4.mp4 from the Moments-In-Time dataset.

Note that cropping is performed after scaling. In the above example, NVVL performs scaling up from 256 x 256 to 512 x 512 first, then cropping the region [60:60 + 385, 0:512]. See the following section to know more about the transformation options.

VideoLoader options

Please specify the GPU device id when you create a NVVLVideoLoader object. You can also specify the logging level with a argument log_level for the constructor of NVVLVideoLoader.

Wrapper of NVVL VideoLoader

    Args:
        device_id (int): Specify the device id used to load a video.
        log_level (str): Logging level which should be either 'debug',
            'info', 'warn', 'error', or 'none'.
            Logs with levels >= log_level is shown. The default is 'warn'.

Transformation Options

pynvvl.NVVLVideoLoader.read_sequence can take some options to specify the color space, the value range, and what transformations you want to perform to the video.

Loads the video from disk and returns it as a CuPy ndarray.

    Args:
        filename (str): The path to the video.
        frame (int): The initial frame number of the returned sequence.
            Default is 0.
        count (int): The number of frames of the returned sequence.
            If it is None, whole frames of the video are loaded.
        channels (int): The number of color channels of the video.
            Default is 3.
        scale_height (int): The height of the scaled video.
            Note that scaling is performed before cropping.
            If it is 0 no scaling is performed. Default is 0.
        scale_width (int): The width of the scaled video.
            Note that scaling is performed before cropping.
            If it is 0, no scaling is performed. Default is 0.
        crop_x (int): Location of the crop within the scaled frame.
            Must be set such that crop_y + height <= original height.
            Default is 0.
        crop_y (int): Location of the crop within the scaled frame.
            Must be set such that crop_x + width <= original height.
            Default is 0.
        crop_height (int): The height of cropped region of the video.
            If it is None, no cropping is performed. Default is None.
        crop_width (int): The width of cropped region of the video.
            If it is None, no cropping is performed. Default is None.
        scale_method (str): Scaling method. It should be either of
            'Nearest' or 'Lienar'. Default is 'Linear'.
        horiz_flip (bool): Whether horizontal flipping is performed or not.
            Default is False.
        normalized (bool): If it is True, the values of returned video is
            normalized into [0, 1], otherwise the value range is [0, 255].
            Default is False.
        color_space (str): The color space of the values of returned video.
            It should be either 'RGB' or 'YCbCr'. Default is 'RGB'.
        chroma_up_method (str): How the chroma channels are upscaled from
            yuv 4:2:0 to 4:4:4. It should be 'Linear' currently.

How to build wheels

Requirements for build

  • Docker
  • nvidia-docker (v1/v2)
bash docker/build_wheels.sh

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

pynvvl_cuda91-0.0.2a4-cp27-cp27mu-manylinux1_x86_64.whl (1.5 MB view details)

Uploaded CPython 2.7mu

File details

Details for the file pynvvl_cuda91-0.0.2a4-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for pynvvl_cuda91-0.0.2a4-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 8ef7cfd05ab3e07d39d83f9cd8792b9f3d767b897de4155a10ba470bd19aed38
MD5 c32869f2149af7e6eb2c530a20ff8a13
BLAKE2b-256 de668323fd1fb04d73648b510ec4a15298419b5bb16fd2046e73afc8181d0869

See more details on using hashes here.

File details

Details for the file pynvvl_cuda91-0.0.2a4-cp35-cp35m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for pynvvl_cuda91-0.0.2a4-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 f3ef46e2deb1b8c123c6e9236687b13e0d2c9c938a4c5ac6a44b27140ecc7e20
MD5 dce4be6ab7c84592d6c39cf2baeccbe5
BLAKE2b-256 75a38362559876180f02b7b7b277dc89f15be16b91ec2ca11c26494c2da0f9ec

See more details on using hashes here.

File details

Details for the file pynvvl_cuda91-0.0.2a4-cp34-cp34m-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for pynvvl_cuda91-0.0.2a4-cp34-cp34m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 78bbfc023f7c408c17f2256a319b003cd378114a45def319124b7c10653cb713
MD5 42969f327cba9ada0b4a7c3d85f1f0cc
BLAKE2b-256 9669427d643aa3f46fade1fca92b593b9ae96a8d228aa6e9e3f39589185f282a

See more details on using hashes here.

File details

Details for the file pynvvl_cuda91-0.0.2a4-cp27-cp27mu-manylinux1_x86_64.whl.

File metadata

File hashes

Hashes for pynvvl_cuda91-0.0.2a4-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 0f1b3813de3c233ff29856f63ff8c286110f264ba67c46353a329a9eaa45153d
MD5 3b85e43341498a0ae39de771a613fa4f
BLAKE2b-256 818cfea48ea9a1364a2c3cff123a11c75f2c9dbbadd8f1138add22a2a39f17eb

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