/omaf

Nokia OMAF implementation

Primary LanguageC++OtherNOASSERTION

Build Status

Omnidirectional MediA Format (OMAF)

OMAF is a systems standard developed by the Moving Picture Experts Group (MPEG) for enabling standardized omnidirectional media applications, focusing on 360 video, images and audio. OMAF Creator/Player Engine is an implementation of OMAF standard in order to demonstrate its powerful features and capabilities, and to help achieving interoperability between OMAF implementations.

News:

12-Oct-2021: Version 2.2.0 released! Main changes include:

  • Support for OMAFv2 specification
  • Multiple viewpoints and dynamic viewpoint information
  • Overlays and dynamic overlay information
  • Simple tiling profile

16-Jan-2019: Version 2.1.0 released! Main changes include:

  • Windows sample application for OMAF Player supports Direct3D rendering providing improved playback performance (e.g. 6K@60 fps).
  • OMAF Player bug fixes and improvements especially in OMAF HEVC Viewport Dependent profile, OMAF Still image profile, and audio playback.
  • OMAF Player sample application for Windows and Android enable to select input file via dialog (instead of hardcoded filename on source code).
  • Some other quality and stability improvements.

11-Oct-2018: Version 2.0.0 released! Main changes include:

  • OMAF Creator supports creating OMAF HEVC Viewport Dependent profile DASH streams
  • OMAF Creator supports creating OMAF Still Image profile files
  • OMAF Player supports OMAF HEVC Viewport Dependent profile DASH streams with more modes than in version 1
  • OMAF Player supports playing back OMAF Still Image profile files, including one or more images, and with and without grid.
  • Android sample application for OMAF Player is included, operating in handheld mode.

Features:

Nokia OMAF Creator/Player implements a subset of current OMAF version 2 standard, including the following main features:

Multiple viewpoints

  • Each viewpoint may have any type of tiling scheme / projection.

Overlays

  • All features except for 3D mesh overlays and externally specified overlay information.

Convert 360-degree HEVC videos in equirectangular projection stored in conventional mp4 files to OMAF HEVC viewport independent profile files or DASH streams.

  • Input can be identified with filename suffix (_M for mono, _TB for top-bottom framepacked, and _LR for side-by-side framepacked; if no suffix mono is assumed).
  • In addition, mp4 files with Google Spatial Media metadata and HEVC video can be recognized and accepted as input.
  • Output is either a single mp4 file, or DASH live profile MPD and segment files in segment template mode.
  • Both mono and framepacked stereo video in equirectangular projection are supported for file and DASH output.
  • Both OMAF ISOBMFF boxes as well as HEVC omnidirectional video SEI messages are added to the output.
  • AAC audio is passed through to the output file as is.

Create 360-degree OMAF HEVC Viewport Dependent profile DASH streams, from HEVC files that have HEVC tiles.

  • As this requires rather complicated configuration, json configuration file is used instead of command line. See example-omaf-configuration.json under Creator/doc folder, and examples in https://github.com/nokiatech/omaf/wiki/Usage-instructor-for-OMAF-Creator---Viewport-dependent-mode
  • Three viewport dependent modes are supported: Equal-resolution streams with extractor (OMAF Annex D.4.2), Effective 5K ERP (Annex D.6.2/second example), and Effective 6K ERP (Annex D.6.3).
  • Output is DASH live profile MPD and segment files, in segment template mode. The Creator can be configured also to output a single mp4 file, but it does not contain all the tracks that the DASH has. E.g. in single resolution mode, it has video tracks only for the best quality case, and in unequal resolution case it has only 1 extractor track (one viewing direction).
  • Both mono and framepacked stereo video in equirectangular projection are supported for file and DASH output.
  • OMAF signalling in MPD, OMAF ISOBMFF boxes as well as HEVC omnidirectional video SEI messages are supported.
  • Multiple representations to achieve bitrate adaptation is not supported.

Create 360-degree OMAF Still Image profile files, from HEVC files.

  • Input is HEVC bitstream, or multiple HEVC bitstreams if image sequence output is generated.
  • Output is a single heic file.
  • Both mono and framepacked stereo in equirectangular projection are supported.

Playback OMAF HEVC Viewport-Independent and Viewport Dependent files and DASH streams (a sample application for Windows provided)

  • Both mono and framepacked stereo video are supported.
  • The same viewport dependent schemes as produced by the Creator are supported, in both Equirectangular and Cubemap projection formats.
  • Viewport dependency is effective only with DASH streaming. Note! Tile switching latency may be further optimized.
  • Extractor track definition in MPD using Preselections descriptor is supported, @dependencyId is supported also in single resolution case.
  • Spherical quality ranking is supported to the extent needed for the supported viewport dependent schemes, but 2D region-wise quality ranking is not supported.
  • Initial viewing orientation and rotation are supported on local playback, but on DASH streaming the initial viewing orientation is not yet supported.
  • DASH live profile streams are supported. All DASH modes other than segment template mode for OMAF viewport dependent delivery are experimental.
  • Bitrate adaptation support is disabled.

Playback OMAF Still Image files (a sample application for Windows provided)

  • Both mono and framepacked stereo images are supported.
  • Images in image sequences can be browsed by clicking space.

All the components compile and run on Windows 10. OMAF Player requires in practice an HW accelerated HEVC decoder on Windows, available e.g. with NVidia 10xx display cards. With Direct3D, it is set as 6k@60 fps, which is ~8k@33 fps. OMAF Creator can be compiled and run on Windows 10 and Linux.

Contents of the Repository:

This repository contains the following items:

  • OMAF Creator with the following command-line applications: omafvi.exe, omafvd.exe, and omafimage.exe
  • OMAF Player engine
  • OMAF Player sample applications for Windows
  • OMAF MP4 reader and writer library, used by the Creator and Player.

In addition, a LibDASH fork is provided in a separate repository: LibDASH, and OMAF branch of the HEIF repository heif is utilized as well.

Supported operating systems

OMAF Player

  • Windows 10

OMAF Creator

  • Windows 10
  • Linux

Building source:

Cmake-based build scripts are provided. A CMake installation is required, version 3.8 or newer recommended

  • For Linux gcc 6+ is required
  • For Windows, Visual Studio 2019 installation is expected

First clone the LibDASH to the root of your work area. Then clone the OMAF branch of HEIF to the root of your work area. And finally clone this OMAF repository to the same place, i.e. root of your work area, so that the three cloned repositories are adjacent to each other. For example:

`mkdir omaf-build`
`cd omaf-build`
`git clone https://github.com/nokia/libdash`
`git clone --single-branch -b OMAF https://github.com/nokiatech/heif.git`
`git clone https://github.com/nokiatech/omaf.git`

Go to OMAF/Build and execute build-visualstudio.bat or some other build script depending on your platform. It will echo the detailed usage allowing to select which parts to compile.

The Creator binary should appear in /Creator/bin/{OS}/{Debug/Release}/

The Player libraries should appear in /Player/Lib/{OS}/{Debug/Release}/ The Player sample application Visual Studio solution can be opened in \Player\VideoPlayback\Windows\Monitor_Sample.

The player supports by default both Direct3D and OpenGL on Windows. The sample player application from release 2.1 onwards supports D3D, so OpenGL support is not necessarily required. If the OMAF Player is compiled with OpenGL enabled, OpenGL extension headers need to be downloaded and placed under OpenGLExt directory, see Khronos Note that with OpenGL, the max playback rate is restricted to 4k@30 fps.

Usage:

Convert a mono 360 mp4 to OMAF mp4:

omafvi.exe -i file.mp4 -o omaf.mp4

See the Wiki for other viewport independent conversion cases: https://github.com/nokiatech/omaf/wiki/Usage-instructions-for-OMAF-Creator

Create a Viewport dependent profile DASH stream:

omafvd.exe config.json

See the Wiki for explanation of the json configuration for viewport dependent stream generation: https://github.com/nokiatech/omaf/wiki/Usage-instructor-for-OMAF-Creator---Viewport-dependent-mode

Create OMAF Still image profile heic files:

omafimage.exe -s image.265 -o image.heic

See the Wiki for more detailed explanation of OMAF Still Image creation: https://github.com/nokiatech/omaf/wiki/Usage-instructions-for-OMAF-Creator-Still-Image-file-creation

Playback an OMAF file / DASH stream on Windows

\Player\VideoPlayback\Windows\Monitor_Sample\x64\Release\Monitor_sample.exe
The application shows a list of available .mp4, .heic, and .uri files from the directory where the binaries are, or when run on debugger, from \Player\VideoPlayback\Windows\Monitor_Sample. .uri files are text files with .uri extension, used for specifying DASH stream URL, i.e. the location of the MPD, e.g. http://myserver.com/omaf/video.mpd
You can also specify the input name as a command line argument, e.g. Monitor_sample.exe storage://video.mp4 or Monitor_sample.exe http://myserver.com/omaf/video.mpd

License:

Please see LICENSE.TXT file for the terms of use of the contents of this repository.

For more information, please contact: omaf@nokia.com

Copyright (c) 2018-2021 Nokia Corporation and/or its subsidiary(-ies).

All rights reserved.