diff --git a/thirdparty/OpenImageDenoise/bin/OpenImageDenoise.dll b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise.dll new file mode 100644 index 0000000..2af8d1b Binary files /dev/null and b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise.dll differ diff --git a/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_core.dll b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_core.dll new file mode 100644 index 0000000..12d6a8d Binary files /dev/null and b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_core.dll differ diff --git a/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_device_cpu.dll b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_device_cpu.dll new file mode 100644 index 0000000..8cb6487 Binary files /dev/null and b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_device_cpu.dll differ diff --git a/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_device_cuda.dll b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_device_cuda.dll new file mode 100644 index 0000000..cd69c44 Binary files /dev/null and b/thirdparty/OpenImageDenoise/bin/OpenImageDenoise_device_cuda.dll differ diff --git a/thirdparty/OpenImageDenoise/include/OpenImageDenoise/config.h b/thirdparty/OpenImageDenoise/include/OpenImageDenoise/config.h new file mode 100644 index 0000000..f6ee70f --- /dev/null +++ b/thirdparty/OpenImageDenoise/include/OpenImageDenoise/config.h @@ -0,0 +1,78 @@ +// Copyright 2018 Intel Corporation +// SPDX-License-Identifier: Apache-2.0 + +#pragma once + +#define OIDN_VERSION_MAJOR 2 +#define OIDN_VERSION_MINOR 1 +#define OIDN_VERSION_PATCH 0 +#define OIDN_VERSION 20100 +#define OIDN_VERSION_STRING "2.1.0" + +/* #undef OIDN_API_NAMESPACE */ +/* #undef OIDN_STATIC_LIB */ + +#if defined(OIDN_API_NAMESPACE) + #define OIDN_API_NAMESPACE_BEGIN namespace { + #define OIDN_API_NAMESPACE_END } + #define OIDN_API_NAMESPACE_USING using namespace ; + #define OIDN_API_EXTERN_C + #define OIDN_NAMESPACE ::oidn + #define OIDN_NAMESPACE_C _oidn + #define OIDN_NAMESPACE_BEGIN namespace { namespace oidn { + #define OIDN_NAMESPACE_END }} +#else + #define OIDN_API_NAMESPACE_BEGIN + #define OIDN_API_NAMESPACE_END + #define OIDN_API_NAMESPACE_USING + #if defined(__cplusplus) + #define OIDN_API_EXTERN_C extern "C" + #else + #define OIDN_API_EXTERN_C + #endif + #define OIDN_NAMESPACE oidn + #define OIDN_NAMESPACE_C oidn + #define OIDN_NAMESPACE_BEGIN namespace oidn { + #define OIDN_NAMESPACE_END } +#endif + +#define OIDN_NAMESPACE_USING using namespace OIDN_NAMESPACE; + +#if defined(OIDN_STATIC_LIB) + #define OIDN_API_IMPORT OIDN_API_EXTERN_C + #define OIDN_API_EXPORT OIDN_API_EXTERN_C +#elif defined(_WIN32) + #define OIDN_API_IMPORT OIDN_API_EXTERN_C __declspec(dllimport) + #define OIDN_API_EXPORT OIDN_API_EXTERN_C __declspec(dllexport) +#else + #define OIDN_API_IMPORT OIDN_API_EXTERN_C + #define OIDN_API_EXPORT OIDN_API_EXTERN_C __attribute__((visibility ("default"))) +#endif + +#if defined(OpenImageDenoise_EXPORTS) + #define OIDN_API OIDN_API_EXPORT +#else + #define OIDN_API OIDN_API_IMPORT +#endif + +#if defined(_WIN32) + #define OIDN_DEPRECATED(msg) __declspec(deprecated(msg)) +#else + #define OIDN_DEPRECATED(msg) __attribute__((deprecated(msg))) +#endif + +#if !defined(OIDN_DEVICE_CPU) + #define OIDN_DEVICE_CPU +#endif +#if !defined(OIDN_DEVICE_SYCL) +/* #undef OIDN_DEVICE_SYCL */ +#endif +#if !defined(OIDN_DEVICE_CUDA) + #define OIDN_DEVICE_CUDA +#endif +#if !defined(OIDN_DEVICE_HIP) +/* #undef OIDN_DEVICE_HIP */ +#endif + +#define OIDN_FILTER_RT +#define OIDN_FILTER_RTLIGHTMAP diff --git a/thirdparty/OpenImageDenoise/lib/OpenImageDenoise_core.lib b/thirdparty/OpenImageDenoise/lib/OpenImageDenoise_core.lib new file mode 100644 index 0000000..f06cad5 Binary files /dev/null and b/thirdparty/OpenImageDenoise/lib/OpenImageDenoise_core.lib differ diff --git a/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseConfig.cmake b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseConfig.cmake new file mode 100644 index 0000000..ccacd2b --- /dev/null +++ b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseConfig.cmake @@ -0,0 +1,47 @@ +## Copyright 2023 Intel Corporation +## SPDX-License-Identifier: Apache-2.0 + + +####### Expanded from @PACKAGE_INIT@ by configure_package_config_file() ####### +####### Any changes to this file will be overwritten by the next CMake run #### +####### The input file was Config.cmake.in ######## + +get_filename_component(PACKAGE_PREFIX_DIR "${CMAKE_CURRENT_LIST_DIR}/../../../" ABSOLUTE) + +macro(set_and_check _var _file) + set(${_var} "${_file}") + if(NOT EXISTS "${_file}") + message(FATAL_ERROR "File or directory ${_file} referenced by variable ${_var} does not exist !") + endif() +endmacro() + +macro(check_required_components _NAME) + foreach(comp ${${_NAME}_FIND_COMPONENTS}) + if(NOT ${_NAME}_${comp}_FOUND) + if(${_NAME}_FIND_REQUIRED_${comp}) + set(${_NAME}_FOUND FALSE) + endif() + endif() + endforeach() +endmacro() + +#################################################################################### + +set(OIDN_DEVICE_CPU ON) +set(OIDN_DEVICE_SYCL OFF) +set(OIDN_DEVICE_CUDA ON) +set(OIDN_DEVICE_HIP OFF) + +set(OIDN_FILTER_RT ON) +set(OIDN_FILTER_RTLIGHTMAP ON) + +set(OIDN_STATIC_LIB OFF) + +if(OIDN_STATIC_LIB AND OIDN_DEVICE_CPU) + include(CMakeFindDependencyMacro) + find_dependency(TBB) +endif() + +include("${CMAKE_CURRENT_LIST_DIR}/OpenImageDenoiseTargets.cmake") + +check_required_components(OpenImageDenoise) diff --git a/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseConfigVersion.cmake b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseConfigVersion.cmake new file mode 100644 index 0000000..a700e48 --- /dev/null +++ b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseConfigVersion.cmake @@ -0,0 +1,65 @@ +# This is a basic version file for the Config-mode of find_package(). +# It is used by write_basic_package_version_file() as input file for configure_file() +# to create a version-file which can be installed along a config.cmake file. +# +# The created file sets PACKAGE_VERSION_EXACT if the current version string and +# the requested version string are exactly the same and it sets +# PACKAGE_VERSION_COMPATIBLE if the current version is >= requested version, +# but only if the requested major version is the same as the current one. +# The variable CVF_VERSION must be set before calling configure_file(). + + +set(PACKAGE_VERSION "2.1.0") + +if(PACKAGE_VERSION VERSION_LESS PACKAGE_FIND_VERSION) + set(PACKAGE_VERSION_COMPATIBLE FALSE) +else() + + if("2.1.0" MATCHES "^([0-9]+)\\.") + set(CVF_VERSION_MAJOR "${CMAKE_MATCH_1}") + if(NOT CVF_VERSION_MAJOR VERSION_EQUAL 0) + string(REGEX REPLACE "^0+" "" CVF_VERSION_MAJOR "${CVF_VERSION_MAJOR}") + endif() + else() + set(CVF_VERSION_MAJOR "2.1.0") + endif() + + if(PACKAGE_FIND_VERSION_RANGE) + # both endpoints of the range must have the expected major version + math (EXPR CVF_VERSION_MAJOR_NEXT "${CVF_VERSION_MAJOR} + 1") + if (NOT PACKAGE_FIND_VERSION_MIN_MAJOR STREQUAL CVF_VERSION_MAJOR + OR ((PACKAGE_FIND_VERSION_RANGE_MAX STREQUAL "INCLUDE" AND NOT PACKAGE_FIND_VERSION_MAX_MAJOR STREQUAL CVF_VERSION_MAJOR) + OR (PACKAGE_FIND_VERSION_RANGE_MAX STREQUAL "EXCLUDE" AND NOT PACKAGE_FIND_VERSION_MAX VERSION_LESS_EQUAL CVF_VERSION_MAJOR_NEXT))) + set(PACKAGE_VERSION_COMPATIBLE FALSE) + elseif(PACKAGE_FIND_VERSION_MIN_MAJOR STREQUAL CVF_VERSION_MAJOR + AND ((PACKAGE_FIND_VERSION_RANGE_MAX STREQUAL "INCLUDE" AND PACKAGE_VERSION VERSION_LESS_EQUAL PACKAGE_FIND_VERSION_MAX) + OR (PACKAGE_FIND_VERSION_RANGE_MAX STREQUAL "EXCLUDE" AND PACKAGE_VERSION VERSION_LESS PACKAGE_FIND_VERSION_MAX))) + set(PACKAGE_VERSION_COMPATIBLE TRUE) + else() + set(PACKAGE_VERSION_COMPATIBLE FALSE) + endif() + else() + if(PACKAGE_FIND_VERSION_MAJOR STREQUAL CVF_VERSION_MAJOR) + set(PACKAGE_VERSION_COMPATIBLE TRUE) + else() + set(PACKAGE_VERSION_COMPATIBLE FALSE) + endif() + + if(PACKAGE_FIND_VERSION STREQUAL PACKAGE_VERSION) + set(PACKAGE_VERSION_EXACT TRUE) + endif() + endif() +endif() + + +# if the installed or the using project don't have CMAKE_SIZEOF_VOID_P set, ignore it: +if("${CMAKE_SIZEOF_VOID_P}" STREQUAL "" OR "8" STREQUAL "") + return() +endif() + +# check that the installed version has the same 32/64bit-ness as the one which is currently searching: +if(NOT CMAKE_SIZEOF_VOID_P STREQUAL "8") + math(EXPR installedBits "8 * 8") + set(PACKAGE_VERSION "${PACKAGE_VERSION} (${installedBits}bit)") + set(PACKAGE_VERSION_UNSUITABLE TRUE) +endif() diff --git a/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseTargets-release.cmake b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseTargets-release.cmake new file mode 100644 index 0000000..90d58d2 --- /dev/null +++ b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseTargets-release.cmake @@ -0,0 +1,30 @@ +#---------------------------------------------------------------- +# Generated CMake target import file for configuration "Release". +#---------------------------------------------------------------- + +# Commands may need to know the format version. +set(CMAKE_IMPORT_FILE_VERSION 1) + +# Import target "OpenImageDenoise_core" for configuration "Release" +set_property(TARGET OpenImageDenoise_core APPEND PROPERTY IMPORTED_CONFIGURATIONS RELEASE) +set_target_properties(OpenImageDenoise_core PROPERTIES + IMPORTED_IMPLIB_RELEASE "${_IMPORT_PREFIX}/lib/OpenImageDenoise_core.lib" + IMPORTED_LOCATION_RELEASE "${_IMPORT_PREFIX}/bin/OpenImageDenoise_core.dll" + ) + +list(APPEND _cmake_import_check_targets OpenImageDenoise_core ) +list(APPEND _cmake_import_check_files_for_OpenImageDenoise_core "${_IMPORT_PREFIX}/lib/OpenImageDenoise_core.lib" "${_IMPORT_PREFIX}/bin/OpenImageDenoise_core.dll" ) + +# Import target "OpenImageDenoise" for configuration "Release" +set_property(TARGET OpenImageDenoise APPEND PROPERTY IMPORTED_CONFIGURATIONS RELEASE) +set_target_properties(OpenImageDenoise PROPERTIES + IMPORTED_IMPLIB_RELEASE "${_IMPORT_PREFIX}/lib/OpenImageDenoise.lib" + IMPORTED_LINK_DEPENDENT_LIBRARIES_RELEASE "OpenImageDenoise_core" + IMPORTED_LOCATION_RELEASE "${_IMPORT_PREFIX}/bin/OpenImageDenoise.dll" + ) + +list(APPEND _cmake_import_check_targets OpenImageDenoise ) +list(APPEND _cmake_import_check_files_for_OpenImageDenoise "${_IMPORT_PREFIX}/lib/OpenImageDenoise.lib" "${_IMPORT_PREFIX}/bin/OpenImageDenoise.dll" ) + +# Commands beyond this point should not need to know the version. +set(CMAKE_IMPORT_FILE_VERSION) diff --git a/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseTargets.cmake b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseTargets.cmake new file mode 100644 index 0000000..8d36ac3 --- /dev/null +++ b/thirdparty/OpenImageDenoise/lib/cmake/OpenImageDenoise-2.1.0/OpenImageDenoiseTargets.cmake @@ -0,0 +1,119 @@ +# Generated by CMake + +if("${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}" LESS 2.8) + message(FATAL_ERROR "CMake >= 2.8.0 required") +endif() +if(CMAKE_VERSION VERSION_LESS "2.8.3") + message(FATAL_ERROR "CMake >= 2.8.3 required") +endif() +cmake_policy(PUSH) +cmake_policy(VERSION 2.8.3...3.25) +#---------------------------------------------------------------- +# Generated CMake target import file. +#---------------------------------------------------------------- + +# Commands may need to know the format version. +set(CMAKE_IMPORT_FILE_VERSION 1) + +# Protect against multiple inclusion, which would fail when already imported targets are added once more. +set(_cmake_targets_defined "") +set(_cmake_targets_not_defined "") +set(_cmake_expected_targets "") +foreach(_cmake_expected_target IN ITEMS OpenImageDenoise_weights OpenImageDenoise_common OpenImageDenoise_core OpenImageDenoise) + list(APPEND _cmake_expected_targets "${_cmake_expected_target}") + if(TARGET "${_cmake_expected_target}") + list(APPEND _cmake_targets_defined "${_cmake_expected_target}") + else() + list(APPEND _cmake_targets_not_defined "${_cmake_expected_target}") + endif() +endforeach() +unset(_cmake_expected_target) +if(_cmake_targets_defined STREQUAL _cmake_expected_targets) + unset(_cmake_targets_defined) + unset(_cmake_targets_not_defined) + unset(_cmake_expected_targets) + unset(CMAKE_IMPORT_FILE_VERSION) + cmake_policy(POP) + return() +endif() +if(NOT _cmake_targets_defined STREQUAL "") + string(REPLACE ";" ", " _cmake_targets_defined_text "${_cmake_targets_defined}") + string(REPLACE ";" ", " _cmake_targets_not_defined_text "${_cmake_targets_not_defined}") + message(FATAL_ERROR "Some (but not all) targets in this export set were already defined.\nTargets Defined: ${_cmake_targets_defined_text}\nTargets not yet defined: ${_cmake_targets_not_defined_text}\n") +endif() +unset(_cmake_targets_defined) +unset(_cmake_targets_not_defined) +unset(_cmake_expected_targets) + + +# Compute the installation prefix relative to this file. +get_filename_component(_IMPORT_PREFIX "${CMAKE_CURRENT_LIST_FILE}" PATH) +get_filename_component(_IMPORT_PREFIX "${_IMPORT_PREFIX}" PATH) +get_filename_component(_IMPORT_PREFIX "${_IMPORT_PREFIX}" PATH) +get_filename_component(_IMPORT_PREFIX "${_IMPORT_PREFIX}" PATH) +if(_IMPORT_PREFIX STREQUAL "/") + set(_IMPORT_PREFIX "") +endif() + +# Create imported target OpenImageDenoise_weights +add_library(OpenImageDenoise_weights INTERFACE IMPORTED) + +# Create imported target OpenImageDenoise_common +add_library(OpenImageDenoise_common INTERFACE IMPORTED) + +# Create imported target OpenImageDenoise_core +add_library(OpenImageDenoise_core SHARED IMPORTED) + +set_target_properties(OpenImageDenoise_core PROPERTIES + INTERFACE_LINK_LIBRARIES "OpenImageDenoise_common" +) + +# Create imported target OpenImageDenoise +add_library(OpenImageDenoise SHARED IMPORTED) + +set_target_properties(OpenImageDenoise PROPERTIES + INTERFACE_INCLUDE_DIRECTORIES "${_IMPORT_PREFIX}/include" +) + +if(CMAKE_VERSION VERSION_LESS 3.0.0) + message(FATAL_ERROR "This file relies on consumers using CMake 3.0.0 or greater.") +endif() + +# Load information for each installed configuration. +file(GLOB _cmake_config_files "${CMAKE_CURRENT_LIST_DIR}/OpenImageDenoiseTargets-*.cmake") +foreach(_cmake_config_file IN LISTS _cmake_config_files) + include("${_cmake_config_file}") +endforeach() +unset(_cmake_config_file) +unset(_cmake_config_files) + +# Cleanup temporary variables. +set(_IMPORT_PREFIX) + +# Loop over all imported files and verify that they actually exist +foreach(_cmake_target IN LISTS _cmake_import_check_targets) + foreach(_cmake_file IN LISTS "_cmake_import_check_files_for_${_cmake_target}") + if(NOT EXISTS "${_cmake_file}") + message(FATAL_ERROR "The imported target \"${_cmake_target}\" references the file + \"${_cmake_file}\" +but this file does not exist. Possible reasons include: +* The file was deleted, renamed, or moved to another location. +* An install or uninstall procedure did not complete successfully. +* The installation package was faulty and contained + \"${CMAKE_CURRENT_LIST_FILE}\" +but not all the files it references. +") + endif() + endforeach() + unset(_cmake_file) + unset("_cmake_import_check_files_for_${_cmake_target}") +endforeach() +unset(_cmake_target) +unset(_cmake_import_check_targets) + +# This file does not depend on other imported targets which have +# been exported from the same project but in a separate export set. + +# Commands beyond this point should not need to know the version. +set(CMAKE_IMPORT_FILE_VERSION) +cmake_policy(POP) diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/CHANGELOG.md b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/CHANGELOG.md new file mode 100644 index 0000000..dc41741 --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/CHANGELOG.md @@ -0,0 +1,257 @@ +Version History +--------------- + +### Changes in v2.1.0: + +- Added support for denoising 1-channel (e.g. alpha) and 2-channel images +- Added support for arbitrary combinations of input image data types + (e.g. `OIDN_FORMAT_FLOAT3` for `color` but `OIDN_FORMAT_HALF3` for `albedo`) +- Improved performance for most dedicated GPU architectures +- Re-added `OIDN_STATIC_LIB` CMake option which enables building as a static + (CPU support only) or a hybrid static/shared (GPU support as well) library +- Added `release()` method to C++ API objects (`DeviceRef`, `BufferRef`, + `FilterRef`) +- Fixed possible crash when releasing GPU devices, buffers or filters +- Fixed possible crash at process exit for some SYCL runtime versions +- Fixed image quality inconsistency on Intel integrated GPUs, but at the cost + of some performance loss +- Fixed future Windows driver compatibility for Intel integrated GPUs +- Fixed rare output corruption on AMD RDNA2 GPUs +- Fixed device detection on Windows when the path to the library has non-ANSI + characters +- Added support for Intel® oneAPI DPC++/C++ Compiler 2024.0 and compatible + open source compiler versions +- Upgraded to oneTBB 2021.10.0 in the official binaries +- Improved detection of old oneTBB versions + +### Changes in v2.0.1: + +- Fixed performance issue for Intel integrated GPUs using recent Linux drivers +- Fixed crash on systems with both dedicated and integrated AMD GPUs +- Fixed importing `D3D12_RESOURCE`, `D3D11_RESOURCE`, `D3D11_RESOURCE_KMT`, + `D3D11_TEXTURE` and `D3D11_TEXTURE_KMT` external memory types on CUDA and + HIP devices +- Fixed the macOS deployment target of the official x86 binaries (lowered from + 11.0 to 10.11) +- Minor improvements to verbose output + +### Changes in v2.0.0: + +- Added SYCL device for Intel Xe architecture GPUs (Xe-LP, Xe-HPG and Xe-HPC) +- Added CUDA device for NVIDIA Volta, Turing, Ampere, Ada Lovelace and Hopper + architecture GPUs +- Added HIP device for AMD RDNA2 (Navi 21 only) and RDNA3 (Navi 3x) + architecture GPUs +- Added new buffer API functions for specifying the storage type (host, device + or managed), copying data to/from the host, and importing external buffers from + graphics APIs (e.g. Vulkan, Direct3D 12) +- Removed the `oidnMapBuffer` and `oidnUnmapBuffer` functions +- Added support for asynchronous execution (e.g. `oidnExecuteFilterAsync`, + `oidnSyncDevice` functions) +- Added physical device API for querying the supported devices in the system +- Added functions for creating a device from a physical device ID, UUID, LUID + or PCI address (e.g. `oidnNewDeviceByID`) +- Added SYCL, CUDA and HIP interoperability API functions (e.g. `oidnNewSYCLDevice`, + `oidnExecuteSYCLFilterAsync`) +- Added `type` device parameter for querying the device type +- Added `systemMemorySupported` and `managedMemorySupported` device parameters + for querying memory allocations supported by the device +- Added `externalMemoryTypes` device parameter for querying the supported + external memory handle types +- Added `quality` filter parameter for setting the filtering quality mode (high + or balanced quality) +- Minor API changes with backward compatibility: + - Added `oidn(Get|Set)(Device|Filter)(Bool|Int|Float)` functions and + deprecated `oidn(Get|Set)(Device|Filter)(1b|1i|1f)` functions + - Added `oidnUnsetFilter(Image|Data)` functions and deprecated + `oidnRemoveFilter(Image|Data)` functions + - Renamed `alignment` and `overlap` filter parameters to `tileAlignment` + and `tileOverlap` but the old names remain supported +- Removed `OIDN_STATIC_LIB` and `OIDN_STATIC_RUNTIME` CMake options due to + technical limitations +- Fixed over-conservative buffer bounds checking for images with custom strides +- Upgraded to oneTBB 2021.9.0 in the official binaries + +### Changes in v1.4.3: + +- Fixed hardcoded library paths in installed macOS binaries +- Disabled VTune profiling support of oneDNN kernels by default, can be + enabled using CMake options if required (`DNNL_ENABLE_JIT_PROFILING` and + `DNNL_ENABLE_ITT_TASKS`) +- Upgraded to oneTBB 2021.5.0 in the official binaries + +### Changes in v1.4.2: + +- Added support for 16-bit half-precision floating-point images +- Added `oidnGetBufferData` and `oidnGetBufferSize` functions +- Fixed performance issue on x86 hybrid architecture CPUs (e.g. Alder Lake) +- Fixed build error when using OpenImageIO 2.3 or later +- Upgraded to oneTBB 2021.4.0 in the official binaries + +### Changes in v1.4.1: + +- Fixed crash when in-place denoising images with certain unusual resolutions +- Fixed compile error when building for Apple Silicon using some unofficial + builds of ISPC + +### Changes in v1.4.0: + +- Improved fine detail preservation +- Added the `cleanAux` filter parameter for further improving quality when the + auxiliary feature (albedo, normal) images are noise-free +- Added support for denoising auxiliary feature images, which can be used + together with the new `cleanAux` parameter for improving quality when the + auxiliary images are noisy (recommended for final frame denoising) +- Normals are expected to be in the [-1, 1] range (but still do not have to + be normalized) +- Added the `oidnUpdateFilterData` function which must be called when the + contents of an opaque data parameter bound to a filter (e.g. `weights`) has + been changed after committing the filter +- Added the `oidnRemoveFilterImage` and `oidnRemoveFilterData` functions for + removing previously set image and opaque data parameters of filters +- Reduced the overhead of `oidnCommitFilter` to zero in some cases (e.g. when + changing already set image buffers/pointers or the `inputScale` parameter) +- Reduced filter memory consumption by about 35% +- Reduced total memory consumption significantly when using multiple filters + that belong to the same device +- Reduced the default maximum memory consumption to 3000 MB +- Added the `OIDN_FILTER_RT` and `OIDN_FILTER_RTLIGHTMAP` CMake options for + excluding the trained filter weights from the build to significantly + decrease its size +- Fixed detection of static TBB builds on Windows +- Fixed compile error when using future glibc versions +- Added `oidnBenchmark` option for setting custom resolutions +- Upgraded to oneTBB 2021.2.0 in the official binaries + +### Changes in v1.3.0: + +- Improved denoising quality + - Improved sharpness of fine details / less blurriness + - Fewer noisy artifacts +- Slightly improved performance and lowered memory consumption +- Added directional (e.g. spherical harmonics) lightmap denoising to the + `RTLightmap` filter +- Added `inputScale` filter parameter which generalizes the existing + (and thus now deprecated) `hdrScale` parameter for non-HDR images +- Added native support for Apple Silicon and the BNNS library on macOS + (currently requires rebuilding from source) +- Added `OIDN_NEURAL_RUNTIME` CMake option for setting the neural network + runtime library +- Reduced the size of the library binary +- Fixed compile error on some older macOS versions +- Upgraded release builds to use oneTBB 2021.1.1 +- Removed tbbmalloc dependency +- Appended the library version to the name of the directory containing the + installed CMake files +- Training: + - Faster training performance + - Added mixed precision training (enabled by default) + - Added efficient data-parallel training on multiple GPUs + - Enabled preprocessing datasets multiple times with possibly different + options + - Minor bugfixes + +### Changes in v1.2.4: + +- Added OIDN_API_NAMESPACE CMake option that allows to put all API functions + inside a user-defined namespace +- Fixed bug when TBB_USE_GLIBCXX_VERSION is defined +- Fixed compile error when using an old compiler which does not support + OpenMP SIMD +- Added compatibility with oneTBB 2021 +- Export only necessary symbols on Linux and macOS + +### Changes in v1.2.3: + +- Fixed incorrect detection of AVX-512 on macOS (sometimes causing a crash) +- Fixed inconsistent performance and costly initialization for AVX-512 +- Fixed JIT'ed AVX-512 kernels not showing up correctly in VTune + +### Changes in v1.2.2: + +- Fixed unhandled exception when canceling filter execution from the + progress monitor callback function + +### Changes in v1.2.1: + +- Fixed tiling artifacts when in-place denoising (using one of the input + images as the output) high-resolution (> 1080p) images +- Fixed ghosting/color bleeding artifacts in black regions when using + albedo/normal buffers +- Fixed error when building as a static library (`OIDN_STATIC_LIB` option) +- Fixed compile error for ISPC 1.13 and later +- Fixed minor TBB detection issues +- Fixed crash on pre-SSE4 CPUs when using some recent compilers (e.g. GCC 10) +- Link C/C++ runtime library dynamically on Windows too by default +- Renamed example apps (`oidnDenoise`, `oidnTest`) +- Added benchmark app (`oidnBenchmark`) +- Fixed random data augmentation seeding in training +- Fixed training warning with PyTorch 1.5 and later + +### Changes in v1.2.0: + +- Added neural network training code +- Added support for specifying user-trained models at runtime +- Slightly improved denoising quality (e.g. less ringing artifacts, less + blurriness in some cases) +- Improved denoising speed by about 7-38% (mostly depending on the compiler) +- Added `OIDN_STATIC_RUNTIME` CMake option (for Windows only) +- Added support for OpenImageIO to the example apps (disabled by default) +- Added check for minimum supported TBB version +- Find debug versions of TBB +- Added testing + +### Changes in v1.1.0: + +- Added `RTLightmap` filter optimized for lightmaps +- Added `hdrScale` filter parameter for manually specifying the mapping + of HDR color values to luminance levels + +### Changes in v1.0.0: + +- Improved denoising quality + - More details preserved + - Less artifacts (e.g. noisy spots, color bleeding with albedo/normal) +- Added `maxMemoryMB` filter parameter for limiting the maximum memory + consumption regardless of the image resolution, potentially at the cost + of lower denoising speed. This is internally implemented by denoising the + image in tiles +- Significantly reduced memory consumption (but slightly lower performance) + for high resolutions (> 2K) by default: limited to about 6 GB +- Added `alignment` and `overlap` filter parameters that can be queried for + manual tiled denoising +- Added `verbose` device parameter for setting the verbosity of the console + output, and disabled all console output by default +- Fixed crash for zero-sized images + +### Changes in v0.9.0: + +- Reduced memory consumption by about 38% +- Added support for progress monitor callback functions +- Enabled fully concurrent execution when using multiple devices +- Clamp LDR input and output colors to 1 +- Fixed issue where some memory allocation errors were not reported + +### Changes in v0.8.2: + +- Fixed wrong HDR output when the input contains infinities/NaNs +- Fixed wrong output when multiple filters were executed concurrently on + separate devices with AVX-512 support. Currently the filter executions are + serialized as a temporary workaround, and a full fix will be included in a + future release. +- Added `OIDN_STATIC_LIB` CMake option for building as a static library + (requires CMake 3.13.0 or later) +- Fixed CMake error when adding the library with add_subdirectory() to a project + +### Changes in v0.8.1: + +- Fixed wrong path to TBB in the generated CMake configs +- Fixed wrong rpath in the binaries +- Fixed compile error on some macOS systems +- Fixed minor compile issues with Visual Studio +- Lowered the CPU requirement to SSE4.1 +- Minor example update + +### Changes in v0.8.0: + +- Initial beta release diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/LICENSE.txt b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/LICENSE.txt new file mode 100644 index 0000000..5b39b49 --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/LICENSE.txt @@ -0,0 +1,269 @@ +INTEL® OPEN IMAGE DENOISE SOFTWARE +BINARY SOFTWARE LICENSE AGREEMENT + +IMPORTANT NOTICE – PLEASE READ AND AGREE BEFORE DOWNLOADING, INSTALLING, COPYING +OR USING THE SOFTWARE + +This agreement (the "Agreement") is between you, or the company or other legal +entity that you represent and warrant you have the legal authority to bind, +(each, "You" or "Your") and Intel Corporation and its subsidiaries +(collectively, "Intel") regarding Your use of the Software. By downloading, +installing, copying or otherwise using the Software, You agree to be bound by +the terms of this Agreement. If You do not agree to the terms of this +Agreement, or do not have legal authority or required age to agree to them, do +not download, install, copy or otherwise use the Software. + +1. DEFINITIONS. "Derivative Works" means derivative works of the Software as +defined in 17 U.S.C. § 101 et seq. "Reciprocal Open Source Software" means any +software that is subject to a license which requires that (a) it must be +distributed in source code form; (b) it must be licensed under the same open +source license terms; and (c) its Derivative Works must be licensed under the +same open source license terms. Examples of this type of license are the GNU +General Public License or the Mozilla Public License. "Software" means the +Intel® Open Image Denoise software in binary form, printed or electronic +documentation, and any other collateral including any updates and upgrades that +are made available to You by Intel under this Agreement. The Software does not +include Third Party Software. "Third Party Software" mean the third party +software (if any) listed in the "third-party-programs.txt" or other +similarly-named text file that may be included in the Software. + +2. LIMITED LICENSE. Subject to compliance with the terms and conditions of this +Agreement, Intel grants You a limited, nonexclusive, nontransferable, revocable, +worldwide, no fee license during the term of this Agreement, without the right +to sublicense, under Intel’s copyrights, for Your (a) reasonable internal +reproduction and internal use, and (b) redistribution of the Software to end +users provided that: (i) the Software is provided under a written, legally +enforceable end user license agreement that has the effect of protecting the +Software and the rights of Intel and its licensors under terms no less +restrictive than this Agreement, and (ii) You indemnify, defend, and hold +harmless Intel and its licensors from any claims, including attorneys’ fees, +related to the Your redistribution or use of the Software. + +3. OWNERSHIP/LICENSE RESTRICTIONS. All right, title and interest in and to the +Software are and will remain the exclusive property of Intel and its licensors. +Unless expressly permitted under the Agreement, You will not, and will not allow +any third party to (i) use, copy, distribute, transfer, sublicense, rent, sell +or offer to sell the Software or associated documentation; (ii) modify, adapt, +enhance, disassemble, decompile, reverse engineer, change or create Derivative +Works from the Software except and only to the extent as specifically required +by mandatory applicable laws; (iii) use or make the Software available for the +use or benefit of third parties; (iv) modify, create a Derivative Work, link, or +distribute the Software so that any part of it becomes subject to the license +requirements of Reciprocal Open Source Software; (v) remove or alter any +copyright, trademark or patent notice in the Software or any portion; (vi) use +Intel’s or its licensors’ trademarks in Your distribution names or in a way that +suggests Your distributions comes from or is endorsed by Intel or its licensors; +(vii) bypass, disable, or circumvent any encryption, security, digital rights +management or authentication mechanism in the Software; (viii) include the +Software in malicious, deceptive or unlawful programs; (ix) distribute the +Software in source code form; (x) grant the right to modify the Software; or +(xi) reverse engineer, decompile or disassemble any portion of the output +generated using the Software for the purpose of translating such output +artifacts to target a non-NVIDIA platform if the output is intended for use on +an NVIDIA platform. Furthermore, You: (a) acknowledge that an essential basis of +the bargain in this Agreement is that Intel grants You no licenses or other +rights including, but not limited to, patent, copyright, and trade secret, or +other intellectual property licenses or rights to the Software, by implication, +estoppel or otherwise, except for the licenses expressly granted above; (b) +acknowledge there are significant uses of the Software in its original, +unmodified and uncombined form. You may not remove any copyright notices from +the Software; (c) agree to notify Intel in writing of any known or suspected +distribution or use of the Software not in compliance with the requirements of +this Agreement, and to enforce the terms of your agreements with respect to +distributed Software; (d) agree to cooperate with Intel and provide reasonably +requested information to verify your compliance with this Agreement; and (e) +are solely responsible for ensuring that any product or service developed with +the Software includes sufficient features to comply with all applicable legal +and regulatory standards and requirements. + +4. THIRD PARTY SOFTWARE. Third Party Software, even if included with the +distribution of the Software, may be governed by separate license terms, +including without limitation, open source software notices and terms, third +party license terms, other Intel software license terms. Such separate license +terms (and not this Agreement) govern Your use of the Third Party Programs. + +5. Media Format Codecs and Digital Rights Management. You acknowledge and agree +that Your use of the Software as permitted by this Agreement may require You to +procure license(s) from third parties that may hold intellectual property rights +applicable to any media decoding, encoding or transcoding technology (e.g., the +use of an audio or video codec) or software, content, and/or digital rights +management capabilities (the "Technology") of the Software, if any. Should any +such additional licenses be required, You are solely responsible for obtaining +any such licenses and agree to obtain any such licenses at Your own expense. +Intel does not grant any necessary patent or other rights with respect to the +Technology. + +6. LICENSE TO FEEDBACK. This Agreement does not obligate You to provide Intel +with materials, information, comments, suggestions, or other communication +regarding the features, functions, performance or use of the Software +("Feedback"). To the extent You provide Intel with Feedback in a tangible form, +You grant to Intel and its affiliates a non-exclusive, perpetual, sublicensable, +irrevocable, worldwide, royalty-free, fully paid-up and transferable license, to +and under all of Your intellectual property rights, whether perfected or not, to +publicly perform, publicly display, reproduce, use, make, have made, sell, offer +for sale, distribute, import, create Derivative Works of and otherwise exploit +any comments, suggestions, descriptions, ideas or other feedback regarding the +Software provided by You or on Your behalf. + +7. SAFETY-CRITICAL, AND LIFE-SAVING APPLICATIONS; INDEMNITY. The Software may +provide information relevant to safety-critical applications ("Safety-Critical +Applications") to allow compliance with functional safety standards or +requirements. You acknowledge and agree that safety is Your responsibility. To +the extent You use the Software to create, or as part of, products used in +Safety-Critical Applications, it is Your responsibility to design, manage, and +ensure that there are system-level safeguards to anticipate, monitor, and +control system failures, and You agree that You are solely responsible for all +applicable regulatory standards and safety-related requirements concerning Your +use of the Software in Safety Critical Applications. +Should You use the Software for Safety-Critical Applications or in any type of a +system or application in which the failure of the Software could create a +situation where personal injury or death may occur (e.g., medical systems, +life-sustaining or life-saving systems) ("Life-Saving Applications"), You agree +to indemnify, defend, and hold Intel and its representatives harmless against +any claims or lawsuits, costs, damages, and expenses, including reasonable +attorney fees, arising in any way out of Your use of the Software in +Safety-Critical Applications or Life-Saving Applications and claims of product +liability, personal injury or death associated with those applications; even if +such claims allege that Intel was negligent or strictly liable regarding the +design or manufacture of the Software or its failure to warn regarding the +Software. + +8. NO OBLIGATION; NO AGENCY. Intel may make changes to the Software, or items +referenced therein, at any time without notice. Intel is not obligated to +support, update, provide training for, or develop any further versions of the +Software or to grant any license thereto. No agency, franchise, partnership, +joint venture, or employee-employer relationship is intended or created by this +Agreement. + +9. NO WARRANTY. DISCLAIMER. THE SOFTWARE IS PROVIDED "AS IS" AND "WITH ALL +FAULTS.’ INTEL AND ITS LICENSORS EXPRESSLY DISCLAIM ALL WARRANTIES OF ANY KIND +OR NATURE, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING BUT NOT LIMITED TO +ANY WARRANTIES OF MERCHANTABILITY, TITLE, NONINFRINGEMENT, FITNESS FOR A +PARTICULAR PURPOSE, OR THE ABSENCE OF ANY DEFECTS THEREIN, WHETHER LATENT OR +PATENT. NO WARRANTY IS MADE ON THE BASIS OF TRADE USAGE, COURSE OF DEALING OR +COURSE OF TRADE. Intel does not assume, and does not authorize any person to +assume on its behalf, any other liability. Intel may make changes to the +Software, or to items referenced therein, at any time without notice, but is not +obligated to support, update or provide training for the Software under the +terms of this Agreement. + +10. LIMITATION OF LIABILITY. IN NO EVENT WILL INTEL OR ITS AFFILIATES, +LICENSORS OR SUPPLIERS (INCLUDING THEIR RESPECTIVE DIRECTORS, OFFICERS, +EMPLOYEES, AND AGENTS) BE LIABLE FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT +LIMITATION, LOST PROFITS, LOSS OF USE, LOSS OF GOODWILL, BUSINESS INTERRUPTION, +COSTS OF PROCURING SUBSTITUTE PRODUCTS OR LOST DATA) ARISING OUT OF OR IN +RELATION TO THIS AGREEMENT, INCLUDING THE USE OF OR INABILITY TO USE THE +SOFTWARE, WHETHER SUCH LIABILITY ARISES FROM ANY CLAIM BASED UPON BREACH OF +CONTRACT, BREACH OF WARRANTY, TORT (INCLUDING NEGLIGENCE), PRODUCT LIABILITY OR +ANY OTHER CAUSE OF ACTION OR THEORY OF LIABILITY, EVEN IF INTEL HAS BEEN ADVISED +OF THE POSSIBILITY OF SUCH DAMAGES. SOME JURISDICTIONS PROHIBIT EXCLUSION OR +LIMITATION OF LIABILITY FOR IMPLIED WARRANTIES OR CONSEQUENTIAL OR INCIDENTAL +DAMAGES, SO THE ABOVE LIMITATION MAY IN PART NOT APPLY TO YOU. YOU MAY ALSO +HAVE OTHER LEGAL RIGHTS THAT VARY FROM JURISDICTION TO JURISDICTION. IN NO EVENT +WILL INTEL’S, ITS AFFILIATES’ AND LICENSORS’ TOTAL CUMULATIVE LIABILITY UNDER OR +ARISING OUT OF THIS AGREEMENT EXCEED US$10.00. THE LIMITED REMEDIES, WARRANTY +DISCLAIMER AND LIMITED LIABILITY ARE FUNDAMENTAL ELEMENTS OF THE BASIS OF THE +BARGAIN BETWEEN INTEL AND YOU. YOU ACKNOWLEDGE INTEL WOULD BE UNABLE TO PROVIDE +THE SOFTWARE WITHOUT SUCH LIMITATIONS. + +11. TERMINATION AND SURVIVAL. This Agreement will terminate immediately if You +violate any of its terms or conditions. Intel may, at any time, terminate this +Agreement if (i) you commence or participate in any legal proceeding against +Intel or its licensors with respect to the Software; (ii) if Intel decides to no +longer provide the Software in a particular country; or (iii) if Intel, in its +sole discretion, decides to no longer make the Software commercially available. +Upon any termination of this Agreement, all licenses granted to You hereunder +terminate immediately. Upon termination, You will immediately stop use of the +Software, permanently remove the Software from your systems, destroy the +Software, and keep no copies. If requested in writing, you will certify in +writing that you have complied with your obligations under this Section. The +following sections will survive termination of this Agreement: Section 1, 3 +(only with respect to the first sentence), 4, 5, 6, 7, 9, 10, 11, 12, 16, 17, 18 +and 19. + +12. GOVERNING LAW AND JURISDICTION. This Agreement and any dispute arising out +of or relating to it will be governed by the laws of the U.S.A. and Delaware, +without regard to conflict of laws principles. The parties exclude the +application of the United Nations Convention on Contracts for the International +Sale of Goods (1980). The state and federal courts sitting in Delaware, U.S.A. +will have exclusive jurisdiction over any dispute arising out of or relating to +this Agreement. The parties consent to personal jurisdiction and venue in those +courts. A party that obtains a judgment against the other party in the courts +identified in this Section may enforce that judgment in any court that has +jurisdiction over the parties. + +13. EXPORT. You acknowledge that the Software and all related technical +information are subject to export controls and You agree to comply with all laws +and regulations of the United States and other applicable governments governing +export, re-export, import, transfer, distribution, and use of the Software. In +particular, but without limitation, the Software may not be exported or +re-exported (a) into any U.S. embargoed countries or (b) to any person or entity +listed on a denial order published by the U.S. government or any other +applicable governments. By using the Software, You represent and warrant that +You are not located in any such country or on any such list. You also agree +that You will not use the Software for, or sell or transfer them to a third +party who is known or suspected to be involved in, any purposes prohibited by +the U.S. government or other applicable governments, including, without +limitation, the development, design, manufacture, or production of nuclear, +missile, chemical or biological weapons. + +14. GOVERNMENT RESTRICTED RIGHTS. The technical data and computer software +covered by this license is a "Commercial Item," as such term is defined by the +FAR 2.101 (48 C.F.R. 2.101) and is "commercial computer software" and +"commercial computer software documentation" as specified under FAR 12.212 (48 +C.F.R. 12.212) or DFARS 227.7202 (48 C.F.R. 227.7202), as applicable. This +commercial computer software and related documentation is provided to end users +for use by and on behalf of the U.S. Government, with only those rights as are +granted to all other end users pursuant to the terms and conditions herein. + +15. ASSIGNMENT. You may not delegate, assign or transfer this Agreement, the +license(s) granted or any of Your rights or duties hereunder, expressly, by +implication, by operation of law, or otherwise and any attempt to do so, without +Intel’s express prior written consent, will be null and void. Intel may assign, +delegate and transfer this Agreement, and its rights and obligations hereunder, +in its sole discretion. + +16. ENTIRE AGREEMENT. This Agreement contains the complete and exclusive +agreement and understanding between the parties concerning the subject matter of +this Agreement, and supersedes all prior and contemporaneous proposals, +agreements, understanding, negotiations, representations, warranties, +conditions, and communications, oral or written, between the parties relating to +the same subject matter. You acknowledge and agree that in entering into this +Agreement You have not relied on, and will not be entitled to rely on, any oral +or written representations, warranties, conditions, understanding, or +communications that are not expressly set forth in this Agreement. The express +provisions of this Agreement control over any course of performance, course of +dealing, or usage of the trade inconsistent with any of the provisions of this +Agreement. The provisions of this Agreement will prevail notwithstanding any +different, conflicting, or additional provisions that may appear on any purchase +order, acknowledgement, invoice, or other writing issued by either party in +connection with this Agreement. No modification or amendment to this Agreement +will be effective unless in writing and signed by authorized representatives of +each party, and must specifically identify this Agreement by its title and +version; , except that Intel may make changes to the Agreement as it distributes +new versions of the Software. If You received a copy of this Agreement +translated into another language, the English language version of this Agreement +will prevail in the event of any conflict between versions. + +17. SEVERABILITY AND WAIVER. The parties intend that if a court holds that any +provision or part of this Agreement is invalid or unenforceable under applicable +law, the court will modify the provision to the minimum extent necessary to make +it valid and enforceable, or if it cannot be made valid and enforceable, the +parties intend that the court will sever and delete the provision or part from +this Agreement. Any change to or deletion of a provision or part of this +Agreement under this Section will not affect the validity or enforceability of +the remainder of this Agreement, which will continue in full force and effect. +The failure of a party to require performance by the other party of any +provision hereof will not affect the full right to require such performance at +any time thereafter; nor will waiver by a party of a breach of any provision +hereof constitute a waiver of the provision itself. + +18. PRIVACY. YOUR PRIVACY RIGHTS ARE SET FORTH IN INTEL’S PRIVACY NOTICE, WHICH +FORMS A PART OF THIS AGREEMENT. PLEASE REVIEW THE PRIVACY NOTICE AT +HTTP://WWW.INTEL.COM/PRIVACY TO LEARN HOW INTEL COLLECTS, USES AND SHARES +INFORMATION ABOUT YOU. + +19. THIRD PARTY BENEFICIARIES. The Software includes software and materials +from Intel’s licensors. These licensors are intended third party beneficiaries +that may enforce this Agreement with respect to their intellectual property +rights. diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/README.md b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/README.md new file mode 100644 index 0000000..8b85547 --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/README.md @@ -0,0 +1,2073 @@ +# Intel® Open Image Denoise + +This is release v2.1.0 of Intel Open Image Denoise. For changes and new +features see the [changelog](CHANGELOG.md). Visit +https://www.openimagedenoise.org for more information. + +# Overview + +Intel Open Image Denoise is an open source library of high-performance, +high-quality denoising filters for images rendered with ray tracing. +Intel Open Image Denoise is part of the [Intel® oneAPI Rendering +Toolkit](https://software.intel.com/en-us/oneapi/render-kit) and is +released under the permissive [Apache 2.0 +license](http://www.apache.org/licenses/LICENSE-2.0). + +The purpose of Intel Open Image Denoise is to provide an open, +high-quality, efficient, and easy-to-use denoising library that allows +one to significantly reduce rendering times in ray tracing based +rendering applications. It filters out the Monte Carlo noise inherent to +stochastic ray tracing methods like path tracing, reducing the amount of +necessary samples per pixel by even multiple orders of magnitude +(depending on the desired closeness to the ground truth). A simple but +flexible C/C++ API ensures that the library can be easily integrated +into most existing or new rendering solutions. + +At the heart of the Intel Open Image Denoise library is a collection of +efficient deep learning based denoising filters, which were trained to +handle a wide range of samples per pixel (spp), from 1 spp to almost +fully converged. Thus it is suitable for both preview and final-frame +rendering. The filters can denoise images either using only the noisy +color (*beauty*) buffer, or, to preserve as much detail as possible, can +optionally utilize auxiliary feature buffers as well (e.g. albedo, +normal). Such buffers are supported by most renderers as arbitrary +output variables (AOVs) or can be usually implemented with little +effort. + +Although the library ships with a set of pre-trained filter models, it +is not mandatory to use these. To optimize a filter for a specific +renderer, sample count, content type, scene, etc., it is possible to +train the model using the included training toolkit and user-provided +image datasets. + +Intel Open Image Denoise supports a wide variety of CPUs and GPUs from +different vendors: + + - Intel® 64 architecture compatible CPUs (with at least SSE4.1) + + - Apple Silicon CPUs + + - Intel Xe architecture GPUs, both dedicated and integrated, including + Intel® Arc™ A-Series Graphics, Intel® Data Center GPU Flex Series + (Xe-HPG microarchitecture), Intel® Data Center GPU Max Series + (Xe-HPC), 11th-13th Gen Intel® Core™ processor graphics, and related + Intel Pentium® and Celeron® processors (Xe-LP) + + - NVIDIA GPUs with Volta, Turing, Ampere, Ada Lovelace, and Hopper + architectures + + - AMD GPUs with RDNA2 (Navi 21 only) and RDNA3 (Navi 3x) architectures + +It runs on most machines ranging from laptops to workstations and +compute nodes in HPC systems. It is efficient enough to be suitable not +only for offline rendering, but, depending on the hardware used, also +for interactive or even real-time ray tracing. + +Intel Open Image Denoise exploits modern instruction sets like Intel +SSE4, AVX2, and AVX-512 on CPUs, Intel® Xe Matrix Extensions (Intel® +XMX) on Intel GPUs, and tensor cores on NVIDIA GPUs to achieve high +denoising performance. + +## System Requirements + +You need a CPU with SSE4.1 support or Apple Silicon to run Intel Open +Image Denoise, and you need a 64-bit Windows, Linux, or macOS operating +system as well. + +For Intel GPU support, please also install the latest Intel graphics +drivers: + + - Windows: [Intel® Graphics + Driver](https://www.intel.com/content/www/us/en/download/726609/intel-arc-iris-xe-graphics-whql-windows.html) + 31.0.101.4314 or newer for Intel® Arc™ Graphics, 11th-13th Gen + Intel® Core™ processor graphics, and related Intel Pentium® and + Celeron® processors + + - Linux: [Intel® software for General Purpose GPU + capabilities](https://dgpu-docs.intel.com/driver/installation.html) + release + [20230323](https://dgpu-docs.intel.com/releases/stable_602_20230323.html) + or newer + +Using older driver versions is *not* supported and Intel Open Image +Denoise might run with only limited capabilities, have suboptimal +performance or might be unstable. Also, Resizable BAR *must* be enabled +in the BIOS for Intel dedicated GPUs if running on Linux, and strongly +recommended if running on Windows. + +For NVIDIA GPU support, please also install the latest [NVIDIA graphics +drivers](https://www.nvidia.com/en-us/geforce/drivers/): + + - Windows: Version 522.06 or newer + + - Linux: Version 520.61.05 or newer + +For AMD GPU support, please also install the latest [AMD graphics +drivers](https://www.amd.com/en/support): + + - Windows: AMD Software: Adrenalin Edition 23.4.3 Driver Version + 22.40.51.05 or newer + + - Linux: [Radeon Software for + Linux](https://www.amd.com/en/support/linux-drivers) version 22.40.5 + or newer + +## Support and Contact + +Intel Open Image Denoise is under active development, and though we do +our best to guarantee stable release versions a certain number of bugs, +as-yet-missing features, inconsistencies, or any other issues are still +possible. Should you find any such issues please report them immediately +via the [Intel Open Image Denoise GitHub Issue +Tracker](https://github.com/OpenImageDenoise/oidn/issues) (or, if you +should happen to have a fix for it, you can also send us a pull +request); for missing features please contact us via email at +. + +Join our [mailing +list](https://groups.google.com/d/forum/openimagedenoise/) to receive +release announcements and major news regarding Intel Open Image Denoise. + +## Citation + +If you use Intel Open Image Denoise in a research publication, please +cite the project using the following BibTeX entry: + +``` bibtex +@misc{OpenImageDenoise, + author = {Attila T. {\'A}fra}, + title = {{Intel\textsuperscript{\textregistered} Open Image Denoise}}, + year = {2023}, + note = {\url{https://www.openimagedenoise.org}} +} +``` + +# Compilation + +The latest Intel Open Image Denoise sources are always available at the +[Intel Open Image Denoise GitHub +repository](http://github.com/OpenImageDenoise/oidn). The default +`master` branch should always point to the latest tested bugfix release. + +## Prerequisites + +You can clone the latest Intel Open Image Denoise sources using Git with +the [Git Large File Storage (LFS)](https://git-lfs.github.com/) +extension installed: + + git clone --recursive https://github.com/OpenImageDenoise/oidn.git + +Please note that installing the Git LFS extension is *required* to +correctly clone the repository. Cloning without Git LFS will seemingly +succeed but actually some of the files will be invalid and thus +compilation will fail. + +Intel Open Image Denoise currently supports 64-bit Linux, Windows, and +macOS operating systems. Before you can build Intel Open Image Denoise +you need the following basic prerequisites: + + - [CMake](http://www.cmake.org) 3.15 or newer + + - A C++11 compiler (we recommend using a Clang-based compiler but also + support GCC and Microsoft Visual Studio 2015 and newer) + + - Python 3 + +To build support for different types of CPUs and GPUs, the following +additional prerequisites are needed: + +#### CPU device: + + - [Intel® SPMD Program Compiler (ISPC)](http://ispc.github.io) 1.14.1 + or newer. Please obtain a release of ISPC from the [ISPC downloads + page](https://ispc.github.io/downloads.html). The build system looks + for ISPC in the `PATH` and in the directory right “next to” the + checked-out Intel Open Image Denoise sources.\[1\] Alternatively set + the CMake variable `ISPC_EXECUTABLE` to the location of the ISPC + compiler. + + - [Intel® Threading Building + Blocks](https://github.com/oneapi-src/oneTBB) (TBB) 2017 or newer + +#### SYCL device for Intel GPUs: + + - [Intel® oneAPI DPC++/C++ + Compiler](https://www.intel.com/content/www/us/en/developer/tools/oneapi/dpc-compiler.html) + 2024.0 or newer, or the open source [oneAPI DPC++ + Compiler 2023-09-22](https://github.com/intel/llvm/releases/tag/nightly-2023-09-22). + Other SYCL compilers are *not* supported. The open source version of + the compiler is more up-to-date but less stable, so we *strongly* + recommend to use the exact version listed here, and on Linux we also + recommend to rebuild it from source with the `--disable-fusion` + flag. + + - Intel® Graphics Offline Compiler for OpenCL™ Code (OCLOC) + + - Windows: Version + [31.0.101.4824](https://registrationcenter-download.intel.com/akdlm/IRC_NAS/fcd74e0e-43b3-4930-9bad-29c8b9581339/ocloc_win_101.4824.zip) + or newer as a [standalone component of Intel® oneAPI + Toolkits](https://www.intel.com/content/www/us/en/developer/articles/tool/oneapi-standalone-components.html), + which must be extracted and its contents added to the `PATH`. + Also included with [Intel® oneAPI Base + Toolkit](https://www.intel.com/content/www/us/en/developer/tools/oneapi/toolkits.html#base-kit). + + - Linux: Included with [Intel® software for General Purpose GPU + capabilities](https://dgpu-docs.intel.com) release + [20230918](https://dgpu-docs.intel.com/releases/stable_704_30_20230918.html) + or newer (install at least `intel-opencl-icd` on Ubuntu, + `intel-ocloc` on RHEL or SLES). Also available with [Intel® + Graphics Compute Runtime for oneAPI Level Zero and OpenCL™ + Driver](https://github.com/intel/compute-runtime). + + - If using Intel® oneAPI DPC++/C++ Compiler: + [CMake](http://www.cmake.org) 3.25.2 or newer + + - [Ninja](https://ninja-build.org) or Make as the CMake generator. The + Visual Studio generator is *not* supported. + +#### CUDA device for NVIDIA GPUs: + + - [CMake](http://www.cmake.org) 3.18 or newer + + - [NVIDIA CUDA Toolkit](https://developer.nvidia.com/cuda-toolkit) + 11.8 or newer + +#### HIP device for AMD GPUs: + + - [CMake](http://www.cmake.org) 3.21 or newer + + - [Ninja](https://ninja-build.org) or Make as the CMake generator. The + Visual Studio generator is *not* supported. + + - [AMD ROCm (HIP SDK)](https://rocm.docs.amd.com) v5.5.0 or newer. + +Depending on your operating system, you can install some required +dependencies (e.g., TBB) using `yum` or `apt-get` on Linux, +[Homebrew](https://brew.sh) or [MacPorts](https://www.macports.org) on +macOS, and [`vcpkg`](https://vcpkg.io) on Windows. For the other +dependencies please download the necessary packages or installers and +follow the included instructions. + +## Compiling on Linux/macOS + +If you are building with SYCL support on Linux, make sure that the DPC++ +compiler is properly set up. The open source oneAPI DPC++ Compiler can +be downloaded and simply extracted. However, before using the compiler, +the environment must be set up as well with the following command: + + source ./dpcpp_compiler/startup.sh + +The `startup.sh` script will put `clang` and `clang++` from the oneAPI +DPC++ Compiler into your `PATH`. + +Alternatively, if you have installed Intel® oneAPI DPC++/C++ Compiler +instead, you can set up the compiler by sourcing the `vars.sh` script in +the `env` directory of the compiler install directory, for example, + + source /opt/intel/oneAPI/compiler/latest/env/vars.sh + +This script will put the `icx` and `icpx` compiler executables from the +Intel(R) oneAPI DPC++/C++ Compiler in your `PATH`. + + - Create a build directory, and go into it using a command prompt + + mkdir oidn/build + cd oidn/build + + (We do recommend having separate build directories for different + configurations such as release, debug, etc.). + + - CMake will use the default compiler, which on most Linux machines is + `gcc`, but it can be switched to `clang` by executing the following: + + cmake -G Ninja -DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++ .. + + If you are building with SYCL support, you must set the DPC++ + compiler (`clang`/`clang++` or `icx`/`icpx`) as the C/C++ compiler + here. Note that the compiler variables cannot be changed after the + first `cmake` or `ccmake` run. + + - Open the CMake configuration dialog + + ccmake .. + + - Make sure to properly set the build mode and enable the components + and options you need. By default only CPU support is built, so SYCL + and other device support must be enabled manually (e.g. with the + `OIDN_DEVICE_SYCL` option). Then type ’c’onfigure and ’g’enerate. + When back on the command prompt, build the library using + + ninja + +### Entitlements on macOS + +macOS requires notarization of applications as a security mechanism, and +[entitlements must be +declared](https://developer.apple.com/documentation/bundleresources/entitlements) +during the notarization process. Intel Open Image Denoise uses +just-in-time compilation through +[oneDNN](https://github.com/oneapi-src/oneDNN) and requires the +following entitlements: + + - [`com.apple.security.cs.allow-jit`](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_security_cs_allow-jit) + - [`com.apple.security.cs.allow-unsigned-executable-memory`](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_security_cs_allow-unsigned-executable-memory) + - [`com.apple.security.cs.disable-executable-page-protection`](https://developer.apple.com/documentation/bundleresources/entitlements/com_apple_security_cs_disable-executable-page-protection) + +## Compiling on Windows + +If you are building with SYCL support, make sure that the DPC++ compiler +is properly set up. The open source oneAPI DPC++ Compiler can be +downloaded and simply extracted. However, before using the compiler, the +environment must be set up. To achieve this, open the “x64 Native Tools +Command Prompt for VS” that ships with Visual Studio and execute the +following commands: + + set "DPCPP_DIR=path_to_dpcpp_compiler" + set "PATH=%DPCPP_DIR%\bin;%PATH%" + set "PATH=%DPCPP_DIR%\lib;%PATH%" + set "CPATH=%DPCPP_DIR%\include;%CPATH%" + set "INCLUDE=%DPCPP_DIR%\include;%INCLUDE%" + set "LIB=%DPCPP_DIR%\lib;%LIB%" + +The `path_to_dpcpp_compiler` should point to the unpacked oneAPI DPC++ +Compiler. + +Alternatively, if you have installed Intel® oneAPI DPC++/C++ Compiler +instead, you can either open a regular “Command Prompt” and execute the +`vars.bat` script in the `env` directory of the compiler install +directory, for example + + C:\Program Files (x86)\Intel\oneAPI\compiler\latest\env\vars.bat + +or simply open the installed “Intel oneAPI command prompt for Intel 64 +for Visual Studio”. Either way, the `icx` compiler executable from the +Intel® oneAPI DPC++/C++ Compiler will be added to your `PATH`. + +On Windows we highly recommend to use Ninja as the CMake generator +because not all devices can be built using the Visual Studio generator +(e.g. SYCL). + + - Create a build directory, and go into it using a Visual Studio + command prompt + + mkdir oidn/build + cd oidn/build + + (We do recommend having separate build directories for different + configurations such as release, debug, etc.). + + - CMake will use the default compiler, which on most Windows machines + is MSVC, but it can be switched to `clang` by executing the + following: + + cmake -G Ninja -DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++ .. + + If you are building with SYCL support, you must set the DPC++ + compiler (`clang`/`clang++` or `icx`) as the C/C++ compiler here. + Note that the compiler variables cannot be changed after the first + `cmake` or `cmake-gui` run. + + - Open the CMake GUI (`cmake-gui.exe`) + + cmake-gui .. + + - Make sure to properly set the build mode and enable the components + and options you need. By default only CPU support is built, so SYCL + and other device support must be enabled manually + (e.g. `OIDN_DEVICE_SYCL` option). Then click on Configure and + Generate. When back on the command prompt, build the library using + + ninja + +## CMake Configuration + +The following list describes the options that can be configured in +CMake: + + - `CMAKE_BUILD_TYPE`: Can be used to switch between Debug mode + (Debug), Release mode (Release) (default), and Release mode with + enabled assertions and debug symbols (RelWithDebInfo). + + - `OIDN_STATIC_LIB`: Build Open Image Denoise as a static (if only CPU + support is enabled) or a hybrid static/shared (if GPU support is + enabled as well) library. + + - `OIDN_API_NAMESPACE`: Specifies a namespace to put all Intel Open + Image Denoise API symbols inside. This is also added as an outer + namespace for the C++ wrapper API. By default no namespace is used + and plain C symbols are exported. + + - `OIDN_DEVICE_CPU`: Enable CPU device support (ON by default). + + - `OIDN_DEVICE_SYCL`: Enable SYCL device support for Intel GPUs (OFF + by default). + + - `OIDN_DEVICE_SYCL_AOT`: Enable ahead-of-time (AOT) compilation for + SYCL kernels (ON by default). Turning this off removes dependency on + OCLOC at build time and decreases binary size but significantly + increases initialization time at runtime, so it is recommended only + for development. + + - `OIDN_DEVICE_CUDA`: Enable CUDA device support for NVIDIA GPUs (OFF + by default). + + - `OIDN_DEVICE_HIP`: Enable HIP device support for AMD GPUs (OFF by + default). + + - `OIDN_FILTER_RT`: Include the trained weights of the `RT` filter in + the build (ON by default). Turning this OFF significantly decreases + the size of the library binary, while the filter remains functional + if the weights are set by the user at runtime. + + - `OIDN_FILTER_RTLIGHTMAP`: Include the trained weights of the + `RTLightmap` filter in the build (ON by default). + + - `OIDN_APPS`: Enable building example and test applications (ON by + default). + + - `OIDN_APPS_OPENIMAGEIO`: Enable + [OpenImageIO](http://openimageio.org/) support in the example and + test applications to be able to load/save OpenEXR, PNG, and other + image file formats (OFF by default). + + - `OIDN_INSTALL_DEPENDENCIES`: Enable installing the dependencies + (e.g. TBB, SYCL runtime) as well. + + - `TBB_ROOT`: The path to the TBB installation (autodetected by + default). + + - `ROCM_PATH`: The path to the ROCm installation (autodetected by + default). + + - `OPENIMAGEIO_ROOT`: The path to the OpenImageIO installation + (autodetected by default). + +# Documentation + +The following +[documentation](https://github.com/OpenImageDenoise/oidn/blob/master/readme.pdf "Intel Open Image Denoise Documentation") +of Intel Open Image Denoise can also be found as a [pdf +document](https://github.com/OpenImageDenoise/oidn/blob/master/readme.pdf "Intel Open Image Denoise Documentation"). + +# Open Image Denoise API + +Open Image Denoise provides a C99 API (also compatible with C++) and a +C++11 wrapper API as well. For simplicity, this document mostly refers +to the C99 version of the API. + +The API is designed in an object-oriented manner, e.g. it contains +device objects (`OIDNDevice` type), buffer objects (`OIDNBuffer` type), +and filter objects (`OIDNFilter` type). All objects are +reference-counted, and handles can be released by calling the +appropriate release function (e.g. `oidnReleaseDevice`) or retained by +incrementing the reference count (e.g. `oidnRetainDevice`). + +An important aspect of objects is that setting their parameters do not +have an immediate effect (with a few exceptions). Instead, objects with +updated parameters are in an unusable state until the parameters get +explicitly committed to a given object. The commit semantic allows for +batching up multiple small changes, and specifies exactly when changes +to objects will occur. + +All API calls are thread-safe, but operations that use the same device +will be serialized, so the amount of API calls from different threads +should be minimized. + +## Examples + +To have a quick overview of the C99 and C++11 APIs, see the following +simple example code snippets. + +### Basic Denoising (C99 API) + +``` cpp +#include +... + +// Create an Open Image Denoise device +OIDNDevice device = oidnNewDevice(OIDN_DEVICE_TYPE_DEFAULT); // CPU or GPU if available +oidnCommitDevice(device); + +// Create buffers for input/output images accessible by both host (CPU) and device (CPU/GPU) +OIDNBuffer colorBuf = oidnNewBuffer(device, width * height * 3 * sizeof(float)); +OIDNBuffer albedoBuf = ... + +// Create a filter for denoising a beauty (color) image using optional auxiliary images too +// This can be an expensive operation, so try not to create a new filter for every image! +OIDNFilter filter = oidnNewFilter(device, "RT"); // generic ray tracing filter +oidnSetFilterImage(filter, "color", colorBuf, + OIDN_FORMAT_FLOAT3, width, height, 0, 0, 0); // beauty +oidnSetFilterImage(filter, "albedo", albedoBuf, + OIDN_FORMAT_FLOAT3, width, height, 0, 0, 0); // auxiliary +oidnSetFilterImage(filter, "normal", normalBuf, + OIDN_FORMAT_FLOAT3, width, height, 0, 0, 0); // auxiliary +oidnSetFilterImage(filter, "output", colorBuf, + OIDN_FORMAT_FLOAT3, width, height, 0, 0, 0); // denoised beauty +oidnSetFilterBool(filter, "hdr", true); // beauty image is HDR +oidnCommitFilter(filter); + +// Fill the input image buffers +float* colorPtr = (float*)oidnGetBufferData(colorBuf); +... + +// Filter the beauty image +oidnExecuteFilter(filter); + +// Check for errors +const char* errorMessage; +if (oidnGetDeviceError(device, &errorMessage) != OIDN_ERROR_NONE) + printf("Error: %s\n", errorMessage); + +// Cleanup +oidnReleaseBuffer(colorBuf); +... +oidnReleaseFilter(filter); +oidnReleaseDevice(device); +``` + +### Basic Denoising (C++11 API) + +``` cpp +#include +... + +// Create an Open Image Denoise device +oidn::DeviceRef device = oidn::newDevice(); // CPU or GPU if available +device.commit(); + +// Create buffers for input/output images accessible by both host (CPU) and device (CPU/GPU) +oidn::BufferRef colorBuf = device.newBuffer(width * height * 3 * sizeof(float)); +oidn::BufferRef albedoBuf = ... + +// Create a filter for denoising a beauty (color) image using optional auxiliary images too +// This can be an expensive operation, so try no to create a new filter for every image! +oidn::FilterRef filter = device.newFilter("RT"); // generic ray tracing filter +filter.setImage("color", colorBuf, oidn::Format::Float3, width, height); // beauty +filter.setImage("albedo", albedoBuf, oidn::Format::Float3, width, height); // auxiliary +filter.setImage("normal", normalBuf, oidn::Format::Float3, width, height); // auxiliary +filter.setImage("output", colorBuf, oidn::Format::Float3, width, height); // denoised beauty +filter.set("hdr", true); // beauty image is HDR +filter.commit(); + +// Fill the input image buffers +float* colorPtr = (float*)colorBuf.getData(); +... + +// Filter the beauty image +filter.execute(); + +// Check for errors +const char* errorMessage; +if (device.getError(errorMessage) != oidn::Error::None) + std::cout << "Error: " << errorMessage << std::endl; +``` + +### Denoising with Prefiltering (C++11 API) + +``` cpp +// Create a filter for denoising a beauty (color) image using prefiltered auxiliary images too +oidn::FilterRef filter = device.newFilter("RT"); // generic ray tracing filter +filter.setImage("color", colorBuf, oidn::Format::Float3, width, height); // beauty +filter.setImage("albedo", albedoBuf, oidn::Format::Float3, width, height); // auxiliary +filter.setImage("normal", normalBuf, oidn::Format::Float3, width, height); // auxiliary +filter.setImage("output", outputBuf, oidn::Format::Float3, width, height); // denoised beauty +filter.set("hdr", true); // beauty image is HDR +filter.set("cleanAux", true); // auxiliary images will be prefiltered +filter.commit(); + +// Create a separate filter for denoising an auxiliary albedo image (in-place) +oidn::FilterRef albedoFilter = device.newFilter("RT"); // same filter type as for beauty +albedoFilter.setImage("albedo", albedoBuf, oidn::Format::Float3, width, height); +albedoFilter.setImage("output", albedoBuf, oidn::Format::Float3, width, height); +albedoFilter.commit(); + +// Create a separate filter for denoising an auxiliary normal image (in-place) +oidn::FilterRef normalFilter = device.newFilter("RT"); // same filter type as for beauty +normalFilter.setImage("normal", normalBuf, oidn::Format::Float3, width, height); +normalFilter.setImage("output", normalBuf, oidn::Format::Float3, width, height); +normalFilter.commit(); + +// Prefilter the auxiliary images +albedoFilter.execute(); +normalFilter.execute(); + +// Filter the beauty image +filter.execute(); +``` + +## Upgrading from Open Image Denoise 1.x + +Open Image Denoise 2.0 introduces GPU support, which requires +implementing some minor changes in applications. There are also small +API changes, additions and improvements in this new version. In this +section we summarize the necessary code modifications and also briefly +mention the new features that users might find useful when upgrading to +2.0. For a full description of the changes and new functionality, please +see the API reference. + +### Buffers + +The most important required change is related to how data is passed to +Open Image Denoise. If the application is explicitly using only the CPU +(by specifying `OIDN_DEVICE_TYPE_CPU`), no changes should be necessary. +But if it wants to support GPUs as well, passing pointers to memory +allocated with the system allocator (e.g. `malloc`) would raise an error +because GPUs cannot access such memory in almost all cases. + +To ensure compatibility with any kind of device, including GPUs, the +application should use `OIDNBuffer` objects to store all image data +passed to the library. Memory allocated using buffers is by default +accessible by both the host (CPU) and the device (CPU or GPU). + +Ideally, the application should directly read and write image data +to/from such buffers to avoid redundant and inefficient data copying. If +this cannot be implemented, the application should try to minimize the +overhead of copying as much as possible: + + - Data should be copied to/from buffers only if the data in system + memory indeed cannot be accessed by the device. This can be + determined by simply querying the `systemMemorySupported` device + parameter. If system memory is accessible by the device, no buffers + are necessary and filter image parameters can be set with + `oidnSetSharedFilterImage`. + + - If the image data cannot be accessed by the device, buffers must be + created and the data must be copied to/from these buffers. These + buffers should be directly passed to filters as image parameters + instead of the original pointers using `oidnSetFilterImage`. + + - Data should be copied asynchronously using using the new + `oidnReadBufferAsync` and `oidnWriteBufferAsync` functions, which + may achieve higher performance than plain `memcpy`. + + - If image data must be copied, using the default buffer allocation + may not be the most efficient method. If the device memory is not + physically shared with the host memory (e.g. for dedicated GPUs), + higher performance may be achieved by creating the buffers with + device storage (`OIDN_STORAGE_DEVICE`) using the new + `oidnNewBufferWithStorage` function. This way, the buffer data + cannot be directly accessed by the host anymore but this should not + matter because the data must be copied from some other memory + location anyway. However, this ensures that the data is stored only + in high-performance device memory, and the user has full control + over when and how the data is transferred between host and device. + +The `oidnMapBuffer` and `oidnUnmapBuffer` functions have been removed +from the API due to these not being supported by any of the device +backends. Please use `oidnReadBuffer(Async)` and +`oidnWriteBuffer(Async)` instead. + +### Interop with Compute (SYCL, CUDA, HIP) and Graphics (DX, Vulkan) APIs + +If the application is explicitly using a particular device type which +supports unified memory allocations, e.g. SYCL or CUDA, it may directly +pass pointers allocated using the native allocator of the respective +compute API (e.g. `sycl::malloc_device`, `cudaMalloc`) instead of using +buffers. This way, it is the responsibility of the user to correctly +allocate the memory for the device. + +In such cases, it often necessary to have more control over the device +creation as well, to ensure that filtering is running on the intended +device and command queues or streams from the application can be shared +to improve performance. If the application is using the same compute or +graphics API as the Open Image Denoise device, this can be achieved by +creating devices with `oidnNewSYCLDevice`, `oidnNewCUDADevice`, etc. For +some APIs there are additional interoperability functions as well, +e.g. `oidnExecuteSYCLFilterAsync`. + +If the application is using a graphics API which does not support +unified memory allocations, e.g. DX12 or Vulkan, it may be still +possible to share memory between the application and Open Image Denoise +using buffers, avoiding expensive copying through host memory. External +buffers can be imported from graphics APIs with the new +`oidnNewSharedBufferFromFD` and `oidnNewSharedBufferFromWin32Handle` +functions. To use this feature, buffers must be exported in the graphics +API and must be imported in Open Image Denoise using the same kind of +handle. Care must be taken to select an external memory handle type +which is supported by both APIs. The external memory types supported by +an Open Image Denoise device can be queried using the +`externalMemoryTypes` device parameter. Note that some devices do not +support importing external memory at all (e.g. CPUs, and on GPUs it +primarily depends on the installed drivers), so the application should +always implement a fallback too, which copies the data through the host +if there is no other supported way. + +Sharing textures is currently not supported natively but it is still +possible avoid copying texture data by using a linear texture layout +(e.g. `VK_IMAGE_TILING_LINEAR` in Vulkan) and sharing the buffer that +backs this data. In this case, you should ensure that the row stride of +the linear texture data is correctly set. + +Importing external synchronization primitives (e.g. semaphores) from +graphics APIs is not yet supported either but it is planned for a future +release. Meanwhile, synchronizing access to shared memory should be done +on the host using `oidnSyncDevice` and the used graphics API. + +When importing external memory, the application also needs to make sure +that the Open Image Denoise device is running on the same *physical* +device as the graphics API. This can be easily achieved by using the new +physical device feature, described in the next section. + +### Physical Devices + +Although it is possible to explicitly create devices of a particular +type (with, e.g., `OIDN_DEVICE_TYPE_SYCL`), this is often insufficient, +especially if the system has multiple devices of the same type, and with +GPU support it is very common that there are multiple different types of +supported devices in the system (e.g. a CPU and one or more GPUs). + +The 2.0 version of the library introduces a simple *physical device* +API, which enables the application to query the list of supported +physical devices in the system, including their name, type, UUID, LUID, +PCI address, etc. (see `oidnGetNumPhysicalDevices`, +`oidnGetPhysicalDeviceString`, etc.). New logical device +(i.e. `OIDNDevice`) creation functions for have been also introduced, +which enable creating a logical device on a specific physical device: +`oidnNewDeviceByID`, `oidnNewDeviceByUUID`, etc. + +Creating a logical device on a physical device having a particular UUID, +LUID or PCI address is particularly important when importing external +memory from graphics APIs. However, not all device types support all +types of IDs, and some graphics drivers may even report mismatching +UUIDs or LUIDs for the same physical device, so applications should try +to implement multiple identification methods, or at least assume that +identification might fail. + +### Asynchronous Execution + +With the introduction of GPU support, it is now possible to execute some +operations asynchronously, most importantly filtering +(`oidnExecuteFilterAsync`, `oidnExecuteSYCLFilterAsync`) and copying +data (the already mentioned `oidnReadBufferAsync` and +`oidnWriteBufferAsync`). Although these new asynchronous functions can +be used with any device type, it is *not* guaranteed that these will be +actually executed asynchronously. The most important such exceptions are +CPU devices, which are still blocking the calling thread when these +functions are called. + +When using any asynchronous function it is the responsibility of the +application to handle correct synchronization using `oidnSyncDevice`. + +### Filter Quality + +Open Image Denoise still delivers the same high image quality on all +device types as before, including on GPUs. But often filtering +performance is more important than having the highest possible image +quality, so it is now possible to switch between multiple filter quality +modes. Filters have a new parameter called `quality`, which defaults to +the existing high image quality (`OIDN_QUALITY_HIGH`) but a balanced +quality mode (`OIDN_QUALITY_BALANCED`) has been added as well for even +higher performance. We recommend using balanced quality for interactive +and real-time use cases. + +### Small API Changes + +A few existing API functions have been renamed to improve clarity (e.g. +`oidnSetFilter1i` to `oidnSetFilterInt`) but the old function names are +still available as deprecated functions. When compiling legacy code, +warnings will be emitted for these deprecated functions. To upgrade to +the new API, please simply follow the instructions in the warnings. + +Some filter parameters have been also renamed (`alignment` to +`tileAlignment`, `overlap` to `tileOverlap`). When using the old names, +warnings will be emitted at runtime. + +### Building as a Static Library + +The support to build Open Image Denoise as a static library +(`OIDN_STATIC_LIB` CMake option) has been removed due to switching to a +modular library design, which was necessary for adding multi-vendor GPU +support. + +If the main reason for building as a static library would be is the +ability to use multiple versions of Open Image Denoise in the same +process, please use the existing `OIDN_API_NAMESPACE` CMake option +instead. With this feature all symbols of the library will be put into a +custom namespace, which can prevent symbol clashes. + +## Physical Devices + +Systems often have multiple different types of devices supported by Open +Image Denoise (CPUs and GPUs). The application can get the list of +supported *physical devices* and select which of these to use for +denoising. + +The number of supported physical devices can be queried with + +``` cpp +int oidnGetNumPhysicalDevices(); +``` + +The physical devices can be identified using IDs between 0 and +(`oidnGetNumPhysicalDevices()` \(-\) 1), and are ordered *approximately* +from fastest to slowest (e.g., ID of 0 corresponds to the likely fastest +physical device). Note that the reported number and order of physical +devices may change between application runs, so no assumptions should be +made about this list. + +Parameters of these physical devices can be queried using + +``` cpp +bool oidnGetPhysicalDeviceBool (int physicalDeviceID, const char* name); +int oidnGetPhysicalDeviceInt (int physicalDeviceID, const char* name); +unsigned int oidnGetPhysicalDeviceUInt (int physicalDeviceID, const char* name); +const char* oidnGetPhysicalDeviceString(int physicalDeviceID, const char* name); +const void* oidnGetPhysicalDeviceData (int physicalDeviceID, const char* name, + size_t* byteSize); +``` + +where `name` is the name of the parameter, and `byteSize` is the number +of returned bytes for data parameters. The following parameters can be +queried: + +| Type | Name | Description | +| :------- | :-------------------- | :---------------------------------------------------------------------------------------------------------------------------------- | +| `Int` | `type` | device type as an `OIDNDeviceType` value | +| `String` | `name` | name string | +| `Bool` | `uuidSupported` | device supports universally unique identifier (UUID) | +| `Data` | `uuid` | opaque UUID (`OIDN_UUID_SIZE` bytes, exists only if `uuidSupported` is `true`) | +| `Bool` | `luidSupported` | device supports locally unique identifier (UUID) | +| `Data` | `luid` | opaque LUID (`OIDN_LUID_SIZE` bytes, exists only if `luidSupported` is `true`) | +| `UInt` | `nodeMask` | bitfield identifying the node within a linked device adapter corresponding to the device (exists only if `luidSupported` is `true`) | +| `Bool` | `pciAddressSupported` | device supports PCI address | +| `Int` | `pciDomain` | PCI domain (exists only if `pciAddressSupported` is `true`) | +| `Int` | `pciBus` | PCI bus (exists only if `pciAddressSupported` is `true`) | +| `Int` | `pciDevice` | PCI device (exists only if `pciAddressSupported` is `true`) | +| `Int` | `pciFunction` | PCI function (exists only if `pciAddressSupported` is `true`) | + +Constant parameters supported by physical devices. + +## Devices + +Open Image Denoise has a *logical* device concept as well, or simply +referred to as *device*, which allows different components of the +application to use the Open Image Denoise API without interfering with +each other. Each physical device may be associated with one ore more +logical devices. A basic way to create a device is by calling + +``` cpp +OIDNDevice oidnNewDevice(OIDNDeviceType type); +``` + +where the `type` enumeration maps to a specific device implementation, +which can be one of the following: + +| Name | Description | +| :------------------------- | :------------------------------------------------------------------- | +| `OIDN_DEVICE_TYPE_DEFAULT` | select the likely fastest device (same as physical device with ID 0) | +| `OIDN_DEVICE_TYPE_CPU` | CPU device | +| `OIDN_DEVICE_TYPE_SYCL` | SYCL device (requires a supported Intel GPU) | +| `OIDN_DEVICE_TYPE_CUDA` | CUDA device (requires a supported NVIDIA GPU) | +| `OIDN_DEVICE_TYPE_HIP` | HIP device (requires a supported AMD GPU) | + +Supported device types, i.e., valid constants of type `OIDNDeviceType`. + +If there are multiple supported devices of the specified type, an +implementation-dependent default will be selected. + +A device can be created by specifying a physical device ID as well using + +``` cpp +OIDNDevice oidnNewDeviceByID(int physicalDeviceID); +``` + +Applications can manually iterate over the list of physical devices and +select from them based on their properties but there are also some +built-in helper functions as well, which make creating a device by a +particular physical device property easier: + +``` cpp +OIDNDevice oidnNewDeviceByUUID(const void* uuid); +OIDNDevice oidnNewDeviceByLUID(const void* luid); +OIDNDevice oidnNewDeviceByPCIAddress(int pciDomain, int pciBus, int pciDevice, + int pciFunction); +``` + +These functions are particularly useful when the application needs +interoperability with a graphics API (e.g. DX12, Vulkan). However, not +all of these properties may be supported by the intended physical device +(or drivers might even report inconsistent identifiers), so it is +recommended to select by more than one property, if possible. + +If the application requires interoperability with a particular compute +API (SYCL, CUDA, HIP), it is recommended to use one of the following +dedicated functions instead: + +``` cpp +OIDNDevice oidnNewSYCLDevice(const sycl::queue* queues, int numQueues); +OIDNDevice oidnNewCUDADevice(const int* deviceIDs, const cudaStream_t* streams, + int numPairs); +OIDNDevice oidnNewHIPDevice (const int* deviceIDs, const hipStream_t* streams, + int numPairs); +``` + +For SYCL, it is possible to pass one or more SYCL queues which will be +used by Open Image Denoise for all device operations. This is useful +when the application wants to use the same queues for both denoising and +its own operations (e.g. rendering). Passing multiple queues is not +intended to be used for different physical devices but just for a single +SYCL root-device which consists of multiple sub-devices (e.g. Intel® +Data Center GPU Max Series having multiple Xe-Stacks/tiles). The only +supported SYCL backend is oneAPI Level Zero. + +For CUDA and HIP, pairs of CUDA/HIP device IDs and corresponding streams +can be specified but the current implementation supports only one pair. +Negative device IDs correspond to the default device, and a `NULL` +stream corresponds to the default stream on the corresponding device. +Open Image Denoise automatically sets and restores the current CUDA/HIP +device on the calling thread when necessary, thus the current device +does not have to be changed manually by the application. + +Once a device is created, you can call + +``` cpp +bool oidnGetDeviceBool(OIDNDevice device, const char* name); +void oidnSetDeviceBool(OIDNDevice device, const char* name, bool value); +int oidnGetDeviceInt (OIDNDevice device, const char* name); +void oidnSetDeviceInt (OIDNDevice device, const char* name, int value); +int oidnGetDeviceUInt(OIDNDevice device, const char* name); +void oidnSetDeviceUInt(OIDNDevice device, const char* name, unsigned int value); +``` + +to set and get parameter values on the device. Note that some parameters +are constants, thus trying to set them is an error. See the tables below +for the parameters supported by devices. + +| Type | Name | Default | Description | +| :----- | :----------------------- | ---------: | :---------------------------------------------------------------------------------------------------------------------------------------- | +| `Int` | `type` | *constant* | device type as an `OIDNDeviceType` value | +| `Int` | `version` | *constant* | combined version number (major.minor.patch) with two decimal digits per component | +| `Int` | `versionMajor` | *constant* | major version number | +| `Int` | `versionMinor` | *constant* | minor version number | +| `Int` | `versionPatch` | *constant* | patch version number | +| `Bool` | `systemMemorySupported` | *constant* | device can directly access memory allocated with the system allocator (e.g. `malloc`) | +| `Bool` | `managedMemorySupported` | *constant* | device supports buffers created with managed storage (`OIDN_STORAGE_MANAGED`) | +| `Int` | `externalMemoryTypes` | *constant* | bitfield of `OIDNExternalMemoryTypeFlag` values representing the external memory types supported by the device | +| `Int` | `verbose` | 0 | verbosity level of the console output between 0–4; when set to 0, no output is printed, when set to a higher level more output is printed | + +Parameters supported by all devices. + +| Type | Name | Default | Description | +| :----- | :------------ | ------: | :-------------------------------------------------------------------------------------------------------------------------------- | +| `Int` | `numThreads` | 0 | maximum number of threads which the library should use; 0 will set it automatically to get the best performance | +| `Bool` | `setAffinity` | `true` | enables thread affinitization (pinning software threads to hardware threads) if it is necessary for achieving optimal performance | + +Additional parameters supported only by CPU devices. + +Note that the CPU device heavily relies on setting the thread affinities +to achieve optimal performance, so it is highly recommended to leave +this option enabled. However, this may interfere with the application if +that also sets the thread affinities, potentially causing performance +degradation. In such cases, the recommended solution is to either +disable setting the affinities in the application or in Open Image +Denoise, or to always set/reset the affinities before/after each +parallel region in the application (e.g., if using TBB, with +`tbb::task_arena` and `tbb::task_scheduler_observer`). + +Once parameters are set on the created device, the device must be +committed with + +``` cpp +void oidnCommitDevice(OIDNDevice device); +``` + +This device can then be used to construct further objects, such as +buffers and filters. Note that a device can be committed only once +during its lifetime. + +Some functions may execute asynchronously with respect to the host. The +names of these functions are suffixed with `Async`. Asynchronous +operations are executed *in order* on the device but may not block on +the host. Eventually, it is necessary to wait for all asynchronous +operations to complete, which can be done by calling + +``` cpp +void oidnSyncDevice(OIDNDevice device); +``` + +Currently the CPU device does not support asynchronous execution, and +thus the asynchronous versions of functions will block as well. However, +`oidnSyncDevice` should be always called to ensure correctness on GPU +devices too, which do support asynchronous execution. + +Before the application exits, it should release all devices by invoking + +``` cpp +void oidnReleaseDevice(OIDNDevice device); +``` + +Note that Open Image Denoise uses reference counting for all object +types, so this function decreases the reference count of the device, and +if the count reaches 0 the device will automatically get deleted. It is +also possible to increase the reference count by calling + +``` cpp +void oidnRetainDevice(OIDNDevice device); +``` + +An application should typically create only a single device object per +physical device (one for *all* CPUs or one per GPU) as creation can be +very expensive and additional device objects may incur a significant +memory overhead. If required differently, it should only use a small +number of device objects at any given time. + +### Error Handling + +Each user thread has its own error code per device. If an error occurs +when calling an API function, this error code is set to the occurred +error if it stores no previous error. The currently stored error can be +queried by the application via + +``` cpp +OIDNError oidnGetDeviceError(OIDNDevice device, const char** outMessage); +``` + +where `outMessage` can be a pointer to a C string which will be set to a +more descriptive error message, or it can be `NULL`. This function also +clears the error code, which assures that the returned error code is +always the first error occurred since the last invocation of +`oidnGetDeviceError` on the current thread. Note that the optionally +returned error message string is valid only until the next invocation of +the function. + +Alternatively, the application can also register a callback function of +type + +``` cpp +typedef void (*OIDNErrorFunction)(void* userPtr, OIDNError code, const char* message); +``` + +via + +``` cpp +void oidnSetDeviceErrorFunction(OIDNDevice device, OIDNErrorFunction func, void* userPtr); +``` + +to get notified when errors occur. Only a single callback function can +be registered per device, and further invocations overwrite the +previously set callback function, which do *not* require also calling +the `oidnCommitDevice` function. Passing `NULL` as function pointer +disables the registered callback function. When the registered callback +function is invoked, it gets passed the user-defined payload (`userPtr` +argument as specified at registration time), the error code (`code` +argument) of the occurred error, as well as a string (`message` +argument) that further describes the error. The error code is always set +even if an error callback function is registered. It is recommended to +always set a error callback function, to detect all errors. + +When the device construction fails, `oidnNewDevice` returns `NULL` as +device. To detect the error code of a such failed device construction, +pass `NULL` as device to the `oidnGetDeviceError` function. For all +other invocations of `oidnGetDeviceError`, a proper device handle must +be specified. + +The following errors are currently used by Open Image Denoise: + +| Name | Description | +| :-------------------------------- | :----------------------------------------- | +| `OIDN_ERROR_NONE` | no error occurred | +| `OIDN_ERROR_UNKNOWN` | an unknown error occurred | +| `OIDN_ERROR_INVALID_ARGUMENT` | an invalid argument was specified | +| `OIDN_ERROR_INVALID_OPERATION` | the operation is not allowed | +| `OIDN_ERROR_OUT_OF_MEMORY` | not enough memory to execute the operation | +| `OIDN_ERROR_UNSUPPORTED_HARDWARE` | the hardware (CPU/GPU) is not supported | +| `OIDN_ERROR_CANCELLED` | the operation was cancelled by the user | + +Possible error codes, i.e., valid constants of type `OIDNError`. + +### Environment Variables + +Open Image Denoise supports environment variables for overriding certain +settings at runtime, which can be useful for debugging and development: + +| Name | Description | +| :-------------------- | :---------------------------------------------------------------------------------------------------------------------------------- | +| `OIDN_DEFAULT_DEVICE` | overrides what physical device to use with `OIDN_DEVICE_TYPE_DEFAULT`; can be `cpu`, `sycl`, `cuda`, `hip`, or a physical device ID | +| `OIDN_DEVICE_CPU` | value of 0 disables CPU device support | +| `OIDN_DEVICE_SYCL` | value of 0 disables SYCL device support | +| `OIDN_DEVICE_CUDA` | value of 0 disables CUDA device support | +| `OIDN_DEVICE_HIP` | value of 0 disables HIP device support | +| `OIDN_NUM_THREADS` | overrides `numThreads` device parameter | +| `OIDN_SET_AFFINITY` | overrides `setAffinity` device parameter | +| `OIDN_NUM_SUBDEVICES` | overrides number of SYCL sub-devices to use (e.g. for Intel® Data Center GPU Max Series) | +| `OIDN_VERBOSE` | overrides `verbose` device parameter | + +Environment variables supported by Open Image Denoise. + +## Buffers + +Image data can be passed to Open Image Denoise either via pointers to +memory allocated and managed by the user or by creating buffer objects. +Regardless of which method is used, the data must be allocated in a way +that it is accessible by the device (either CPU or GPU). Using buffers +is typically the preferred approach because this ensures that the +allocation requirements are fulfilled regardless of device type. To +create a new data buffer with memory allocated and owned by the device, +use + +``` cpp +OIDNBuffer oidnNewBuffer(OIDNDevice device, size_t byteSize); +``` + +The created buffer is bound to the specified device (`device` argument). +The specified number of bytes (`byteSize`) are allocated at buffer +construction time and deallocated when the buffer is destroyed. The +memory is by default allocated as managed memory automatically migrated +between host and device, if supported, or as pinned host memory +otherwise. + +If this default buffer allocation is not suitable, a buffer can be +created with a manually specified storage mode as well: + +``` cpp +OIDNBuffer oidnNewBufferWithStorage(OIDNDevice device, size_t byteSize, OIDNStorage storage); +``` + +The supported storage modes are the following: + +| Name | Description | +| :----------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| `OIDN_STORAGE_UNDEFINED` | undefined storage mode | +| `OIDN_STORAGE_HOST` | pinned host memory, accessible by both host and device | +| `OIDN_STORAGE_DEVICE` | device memory, *not* accessible by the host | +| `OIDN_STORAGE_MANAGED` | automatically migrated between host and device, accessible by both (*not* supported by all devices, `managedMemorySupported` device parameter must be checked before use) | + +Supported storage modes for buffers, i.e., valid constants of type +`OIDNStorage`. + +Note that the host and device storage modes are supported by all devices +but managed storage is an optional feature. Before using managed +storage, the `managedMemorySupported` device parameter should be +queried. + +It is also possible to create a “shared” data buffer with memory +allocated and managed by the user with + +``` cpp +OIDNBuffer oidnNewSharedBuffer(OIDNDevice device, void* devPtr, size_t byteSize); +``` + +where `devPtr` points to user-managed device-accessible memory and +`byteSize` is its size in bytes. At buffer construction time no buffer +data is allocated, but the buffer data provided by the user is used. The +buffer data must remain valid for as long as the buffer may be used, and +the user is responsible to free the buffer data when no longer required. +The user must also ensure that the memory is accessible by the device by +using allocation functions supported by the device +(e.g. `sycl::malloc_device`, `cudaMalloc`, `hipMalloc`). + +Buffers can be also imported from graphics APIs as external memory, to +avoid expensive copying of data through host memory. Different types of +external memory can be imported from either POSIX file descriptors or +Win32 handles using + +``` cpp +OIDNBuffer oidnNewSharedBufferFromFD(OIDNDevice device, + OIDNExternalMemoryTypeFlag fdType, + int fd, size_t byteSize); + +OIDNBuffer oidnNewSharedBufferFromWin32Handle(OIDNDevice device, + OIDNExternalMemoryTypeFlag handleType, + void* handle, const void* name, size_t byteSize); +``` + +Before exporting memory from the graphics API, the application should +find a handle type which is supported by both the Open Image Denoise +device (see `externalMemoryTypes` device parameter) and the graphics +API. Note that different GPU vendors may support different handle types. +To ensure compatibility with all device types, applications should +support at least `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_OPAQUE_FD` on Windows +and both `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_OPAQUE_FD` and +`OIDN_EXTERNAL_MEMORY_TYPE_FLAG_DMA_BUF` on Linux. All possible external +memory types are listed in the table below. + +| Name | Description | +| :-------------------------------------------------- | :----------------------------------------------------------------------------------------------------------------- | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_NONE` | | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_OPAQUE_FD` | opaque POSIX file descriptor handle (recommended on Linux) | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_DMA_BUF` | file descriptor handle for a Linux dma\_buf (recommended on Linux) | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_OPAQUE_WIN32` | NT handle (recommended on Windows) | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_OPAQUE_WIN32_KMT` | global share (KMT) handle | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_D3D11_TEXTURE` | NT handle returned by `IDXGIResource1::CreateSharedHandle` referring to a Direct3D 11 texture resource | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_D3D11_TEXTURE_KMT` | global share (KMT) handle returned by `IDXGIResource::GetSharedHandle` referring to a Direct3D 11 texture resource | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_D3D11_RESOURCE` | NT handle returned by `IDXGIResource1::CreateSharedHandle` referring to a Direct3D 11 resource | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_D3D11_RESOURCE_KMT` | global share (KMT) handle returned by `IDXGIResource::GetSharedHandle` referring to a Direct3D 11 resource | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_D3D12_HEAP` | NT handle returned by `ID3D12Device::CreateSharedHandle` referring to a Direct3D 12 heap resource | +| `OIDN_EXTERNAL_MEMORY_TYPE_FLAG_D3D12_RESOURCE` | NT handle returned by `ID3D12Device::CreateSharedHandle` referring to a Direct3D 12 committed resource | + +Supported external memory type flags, i.e., valid constants of type +`OIDNExternalMemoryTypeFlag`. + +Similar to device objects, buffer objects are also reference-counted and +can be retained and released by calling the following functions: + +``` cpp +void oidnRetainBuffer (OIDNBuffer buffer); +void oidnReleaseBuffer(OIDNBuffer buffer); +``` + +The size of in bytes and storage mode of the buffer can be queried using + +``` cpp +size_t oidnGetBufferSize (OIDNBuffer buffer); +OIDNStorage oidnGetBufferStorage(OIDNBuffer buffer); +``` + +It is possible to get a pointer directly to the buffer data, which is +usually the preferred way to access the data stored in the buffer: + +``` cpp +void* oidnGetBufferData(OIDNBuffer buffer); +``` + +However, accessing the data on the host through this pointer is possible +only if the buffer was created with a storage mode that enables this, +i.e., any mode *except* `OIDN_STORAGE_DEVICE`. Note that a `NULL` +pointer may be returned if the buffer is empty or getting a pointer to +data with device storage is not supported by the device. + +In some cases better performance can be achieved by using device storage +for buffers. Such data can be accessed on the host by copying to/from +host memory (including pageable system memory) using the following +functions: + +``` cpp +void oidnReadBuffer(OIDNBuffer buffer, + size_t byteOffset, size_t byteSize, void* dstHostPtr); + +void oidnWriteBuffer(OIDNBuffer buffer, + size_t byteOffset, size_t byteSize, const void* srcHostPtr); +``` + +These functions will always block until the read/write operation has +been completed, which is often suboptimal. The following functions may +execute the operation asynchronously if it is supported by the device +(GPUs), or still block otherwise (CPUs): + +``` cpp +void oidnReadBufferAsync(OIDNBuffer buffer, + size_t byteOffset, size_t byteSize, void* dstHostPtr); + +void oidnWriteBufferAsync(OIDNBuffer buffer, + size_t byteOffset, size_t byteSize, const void* srcHostPtr); +``` + +When copying asynchronously, the user must ensure correct +synchronization with the device by calling `oidnSyncDevice` before +accessing the copied data or releasing the buffer. Failure to do so will +result in undefined behavior. + +### Data Format + +Buffers store opaque data and thus have no information about the type +and format of the data. Other objects, e.g. filters, typically require +specifying the format of the data stored in buffers or shared via +pointers. This can be done using the `OIDNFormat` enumeration type: + +| Name | Description | +| :----------------------- | :------------------------------------------- | +| `OIDN_FORMAT_UNDEFINED` | undefined format | +| `OIDN_FORMAT_FLOAT` | 32-bit floating-point scalar | +| `OIDN_FORMAT_FLOAT[234]` | 32-bit floating-point \[234\]-element vector | +| `OIDN_FORMAT_HALF` | 16-bit floating-point scalar | +| `OIDN_FORMAT_HALF[234]` | 16-bit floating-point \[234\]-element vector | + +Supported data formats, i.e., valid constants of type `OIDNFormat`. + +## Filters + +Filters are the main objects in Open Image Denoise that are responsible +for the actual denoising. The library ships with a collection of filters +which are optimized for different types of images and use cases. To +create a filter object, call + +``` cpp +OIDNFilter oidnNewFilter(OIDNDevice device, const char* type); +``` + +where `type` is the name of the filter type to create. The supported +filter types are documented later in this section. + +Creating filter objects can be very expensive, therefore it is +*strongly* recommended to reuse the same filter for denoising as many +images as possible, as long as the these images have the same same size, +format, and features (i.e., only the memory locations and pixel values +may be different). Otherwise (e.g. for images with different +resolutions), reusing the same filter would not have any benefits. + +Once created, filter objects can be retained and released with + +``` cpp +void oidnRetainFilter (OIDNFilter filter); +void oidnReleaseFilter(OIDNFilter filter); +``` + +After creating a filter, it needs to be set up by specifying the input +and output images, and potentially setting other parameter values as +well. + +To set image parameters of a filter, you can use one of the following +functions: + +``` cpp +void oidnSetFilterImage(OIDNFilter filter, const char* name, + OIDNBuffer buffer, OIDNFormat format, + size_t width, size_t height, + size_t byteOffset, + size_t pixelByteStride, size_t rowByteStride); + +void oidnSetSharedFilterImage(OIDNFilter filter, const char* name, + void* devPtr, OIDNFormat format, + size_t width, size_t height, + size_t byteOffset, + size_t pixelByteStride, size_t rowByteStride); +``` + +It is possible to specify either a data buffer object (`buffer` +argument) with the `oidnSetFilterImage` function, or directly a pointer +to user-managed device-accessible data (`devPtr` argument) with the +`oidnSetSharedFilterImage` function. Regardless of whether a buffer or a +pointer is specified, the data *must* be accessible to the device. The +easiest way to guarantee this regardless of the device type (CPU or GPU) +is using buffer objects. + +In both cases, you must also specify the name of the image parameter to +set (`name` argument, e.g. `"color"`, `"output"`), the pixel format +(`format` argument), the width and height of the image in number of +pixels (`width` and `height` arguments), the starting offset of the +image data (`byteOffset` argument), the pixel stride (`pixelByteStride` +argument) and the row stride (`rowByteStride` argument), in number of +bytes. + +If the pixels and/or rows are stored contiguously (tightly packed +without any gaps), you can set `pixelByteStride` and/or `rowByteStride` +to 0 to let the library compute the actual strides automatically, as a +convenience. + +Images support only `FLOAT` and `HALF` pixel formats with up to 3 +channels. Custom image layouts with extra channels (e.g. alpha channel) +or other data are supported as well by specifying a non-zero pixel +stride. This way, expensive image layout conversion and copying can be +avoided but the extra channels will be ignored by the filter. If these +channels also need to be denoised, separate filters can be used. + +To unset a previously set image parameter, returning it to a state as if +it had not been set, call + +``` cpp +void oidnRemoveFilterImage(OIDNFilter filter, const char* name); +``` + +Some special data used by filters are opaque/untyped (e.g. trained model +weights blobs), which can be specified with the +`oidnSetSharedFilterData` function: + +``` cpp +void oidnSetSharedFilterData(OIDNFilter filter, const char* name, + void* hostPtr, size_t byteSize); +``` + +This data (`hostPtr`) must be accessible to the *host*, therefore system +memory allocation is suitable (i.e., there is no reason to use buffer +objects for allocation). + +Modifying the contents of an opaque data parameter after setting it as a +filter parameter is allowed but the filter needs to be notified that the +data has been updated by calling + +``` cpp +void oidnUpdateFilterData(OIDNFilter filter, const char* name); +``` + +Unsetting an opaque data parameter can be performed with + +``` cpp +void oidnRemoveFilterData(OIDNFilter filter, const char* name); +``` + +Filters may have parameters other than buffers as well, which you can +set and get using the following functions: + +``` cpp +bool oidnGetFilterBool (OIDNFilter filter, const char* name); +void oidnSetFilterBool (OIDNFilter filter, const char* name, bool value); +int oidnGetFilterInt (OIDNFilter filter, const char* name); +void oidnSetFilterInt (OIDNFilter filter, const char* name, int value); +float oidnGetFilterFloat(OIDNFilter filter, const char* name); +void oidnSetFilterFloat(OIDNFilter filter, const char* name, float value); +``` + +Filters support a progress monitor callback mechanism that can be used +to report progress of filter operations and to cancel them as well. +Calling `oidnSetFilterProgressMonitorFunction` registers a progress +monitor callback function (`func` argument) with payload (`userPtr` +argument) for the specified filter (`filter` argument): + +``` cpp +typedef bool (*OIDNProgressMonitorFunction)(void* userPtr, double n); + +void oidnSetFilterProgressMonitorFunction(OIDNFilter filter, + OIDNProgressMonitorFunction func, + void* userPtr); +``` + +Only a single callback function can be registered per filter, and +further invocations overwrite the previously set callback function. +Passing `NULL` as function pointer disables the registered callback +function. Once registered, Open Image Denoise will invoke the callback +function multiple times during filter operations, by passing the payload +as set at registration time (`userPtr` argument), and a `double` in the +range \[0, 1\] which estimates the progress of the operation (`n` +argument). When returning `true` from the callback function, Open Image +Denoise will continue the filter operation normally. When returning +`false`, the library will attempt to cancel the filter operation as soon +as possible, and if that is fulfilled, it will raise an +`OIDN_ERROR_CANCELLED` error. + +Please note that using a progress monitor callback function introduces +some overhead, which may be significant on GPU devices, hurting +performance. Therefore we recommend progress monitoring only for offline +denoising, when denoising an image is expected to take several seconds. + +After setting all necessary parameters for the filter, the changes must +be committed by calling + +``` cpp +void oidnCommitFilter(OIDNFilter filter); +``` + +The parameters can be updated after committing the filter, but it must +be re-committed for any new changes to take effect. Committing major +changes to the filter (e.g. setting new image parameters, changing the +image resolution) can be expensive, and thus should not be done +frequently (e.g. per frame). + +Finally, an image can be filtered by executing the filter with + +``` cpp +void oidnExecuteFilter(OIDNFilter filter); +``` + +which will read the input image data from the specified buffers and +produce the denoised output image. + +This function will always block until the filtering operation has been +completed. The following function may execute the operation +asynchronously if it is supported by the device (GPUs), or block +otherwise (CPUs): + +``` cpp +void oidnExecuteFilterAsync(OIDNFilter filter); +``` + +For filters created on a SYCL device it is also possible to specify +dependent SYCL events (`depEvents` and `numDepEvents` arguments, may be +`NULL`/0) and get a completion event as well (`doneEvent` argument, may +be `NULL`): + +``` cpp +void oidnExecuteSYCLFilterAsync(OIDNFilter filter, + const sycl::event* depEvents, int numDepEvents, + sycl::event* doneEvent); +``` + +When filtering asynchronously, the user must ensure correct +synchronization with the device by calling `oidnSyncDevice` before +accessing the output image data or releasing the filter. Failure to do +so will result in undefined behavior. + +In the following we describe the different filters that are currently +implemented in Open Image Denoise. + +### RT + +The `RT` (**r**ay **t**racing) filter is a generic ray tracing denoising +filter which is suitable for denoising images rendered with Monte Carlo +ray tracing methods like unidirectional and bidirectional path tracing. +It supports depth of field and motion blur as well, but it is *not* +temporally stable. The filter is based on a convolutional neural network +(CNN) and comes with a set of pre-trained models that work well with a +wide range of ray tracing based renderers and noise levels. + +![](https://openimagedenoise.github.io/images/mazda_4spp_input.jpg) +Example noisy beauty image rendered using unidirectional path tracing +(4 samples per pixel). *Scene by +Evermotion.* + +![](https://openimagedenoise.github.io/images/mazda_4spp_oidn.jpg) +Example output beauty image denoised using prefiltered auxiliary +feature images (albedo and normal) +too. + +For denoising *beauty* images, it accepts either a low dynamic range +(LDR) or high dynamic range (HDR) image (`color`) as the main input +image. In addition to this, it also accepts *auxiliary feature* images, +`albedo` and `normal`, which are optional inputs that usually improve +the denoising quality significantly, preserving more details. + +It is possible to denoise auxiliary images as well, in which case only +the respective auxiliary image has to be specified as input, instead of +the beauty image. This can be done as a *prefiltering* step to further +improve the quality of the denoised beauty image. + +The `RT` filter has certain limitations regarding the supported input +images. Most notably, it cannot denoise images that were not rendered +with ray tracing. Another important limitation is related to +anti-aliasing filters. Most renderers use a high-quality pixel +reconstruction filter instead of a trivial box filter to minimize +aliasing artifacts (e.g. Gaussian, Blackman-Harris). The `RT` filter +does support such pixel filters but only if implemented with importance +sampling. Weighted pixel sampling (sometimes called *splatting*) +introduces correlation between neighboring pixels, which causes the +denoising to fail (the noise will not be filtered), thus it is not +supported. + +The filter can be created by passing `"RT"` to the `oidnNewFilter` +function as the filter type. The filter supports the parameters listed +in the table below. All specified images must have the same dimensions. +The output image can be one of the input images (i.e. in-place denoising +is supported). See section [Examples](#examples) for simple code +snippets that demonstrate the usage of the filter. + +| Type | Name | Default | Description | +| :------ | :-------------- | ---------: | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `Image` | `color` | *optional* | input beauty image (1–3 channels, LDR values in \[0, 1\] or HDR values in \[0, +∞), values being interpreted such that, after scaling with the `inputScale` parameter, a value of 1 corresponds to a luminance level of 100 cd/m²) | +| `Image` | `albedo` | *optional* | input auxiliary image containing the albedo per pixel (3 channels, values in \[0, 1\]) | +| `Image` | `normal` | *optional* | input auxiliary image containing the shading normal per pixel (3 channels, world-space or view-space vectors with arbitrary length, values in \[-1, 1\]) | +| `Image` | `output` | *required* | output image (1–3 channels); can be one of the input images | +| `Bool` | `hdr` | `false` | the main input image is HDR | +| `Bool` | `srgb` | `false` | the main input image is encoded with the sRGB (or 2.2 gamma) curve (LDR only) or is linear; the output will be encoded with the same curve | +| `Float` | `inputScale` | NaN | scales values in the main input image before filtering, without scaling the output too, which can be used to map color or auxiliary feature values to the expected range, e.g. for mapping HDR values to physical units (which affects the quality of the output but *not* the range of the output values); if set to NaN, the scale is computed implicitly for HDR images or set to 1 otherwise | +| `Bool` | `cleanAux` | `false` | the auxiliary feature (albedo, normal) images are noise-free; recommended for highest quality but should *not* be enabled for noisy auxiliary images to avoid residual noise | +| `Int` | `quality` | high | image quality mode as an `OIDNQuality` value | +| `Data` | `weights` | *optional* | trained model weights blob | +| `Int` | `maxMemoryMB` | \-1 | if set to \>= 0, an attempt will be made to limit the memory usage below the specified amount in megabytes at the potential cost of slower performance but actual memory usage may be higher (the target may not be achievable or the device may not support this feature at all); otherwise memory usage will be limited to an unspecified device-dependent amount | +| `Int` | `tileAlignment` | *constant* | when manually denoising in tiles, the tile size and offsets should be multiples of this amount of pixels to avoid artifacts; when denoising HDR images `inputScale` *must* be set by the user to avoid seam artifacts | +| `Int` | `tileOverlap` | *constant* | when manually denoising in tiles, the tiles should overlap by this amount of pixels | + +Parameters supported by the `RT` filter. + +Using auxiliary feature images like albedo and normal helps preserving +fine details and textures in the image thus can significantly improve +denoising quality. These images should typically contain feature values +for the first hit (i.e. the surface which is directly visible) per +pixel. This works well for most surfaces but does not provide any +benefits for reflections and objects visible through transparent +surfaces (compared to just using the color as input). However, this +issue can be usually fixed by storing feature values for a subsequent +hit (i.e. the reflection and/or refraction) instead of the first hit. +For example, it usually works well to follow perfect specular (*delta*) +paths and store features for the first diffuse or glossy surface hit +instead (e.g. for perfect specular dielectrics and mirrors). This can +greatly improve the quality of reflections and transmission. We will +describe this approach in more detail in the following subsections. + +The auxiliary feature images should be as noise-free as possible. It is +not a strict requirement but too much noise in the feature images may +cause residual noise in the output. Ideally, these should be completely +noise-free. If this is the case, this should be hinted to the filter +using the `cleanAux` parameter to ensure the highest possible image +quality. But this parameter should be used with care: if enabled, any +noise present in the auxiliary images will end up in the denoised image +as well, as residual noise. Thus, `cleanAux` should be enabled only if +the auxiliary images are guaranteed to be noise-free. + +Usually it is difficult to provide clean feature images, and some +residual noise might be present in the output even with `cleanAux` being +disabled. To eliminate this noise and to even improve the sharpness of +texture details, the auxiliary images should be first denoised in a +prefiltering step, as mentioned earlier. Then, these denoised auxiliary +images could be used for denoising the beauty image. Since these are now +noise-free, the `cleanAux` parameter should be enabled. See section +[Denoising with prefiltering (C++11 +API)](#denoising-with-prefiltering-c11-api) for a simple code example. +Prefiltering makes denoising much more expensive but if there are +multiple color AOVs to denoise, the prefiltered auxiliary images can be +reused for denoising multiple AOVs, amortizing the cost of the +prefiltering step. + +Thus, for final-frame denoising, where the best possible image quality +is required, it is recommended to prefilter the auxiliary features if +they are noisy and enable the `cleanAux` parameter. Denoising with noisy +auxiliary features should be reserved for previews and interactive +rendering. + +All auxiliary images should use the same pixel reconstruction filter as +the beauty image. Using a properly anti-aliased beauty image but aliased +albedo or normal images will likely introduce artifacts around edges. + +#### Albedos + +The albedo image is the feature image that usually provides the biggest +quality improvement. It should contain the approximate color of the +surfaces independent of illumination and viewing angle. + +![](https://openimagedenoise.github.io/images/mazda_firsthit_512spp_albedo.jpg) +Example albedo image obtained using the first hit. Note that the +albedos of all transparent surfaces are +1. + +![](https://openimagedenoise.github.io/images/mazda_nondeltahit_512spp_albedo.jpg) +Example albedo image obtained using the first diffuse or glossy +(non-delta) hit. Note that the albedos of perfect specular (delta) +transparent surfaces are computed as the Fresnel blend of the reflected +and transmitted +albedos. + +For simple matte surfaces this means using the diffuse color/texture as +the albedo. For other, more complex surfaces it is not always obvious +what is the best way to compute the albedo, but the denoising filter is +flexible to a certain extent and works well with differently computed +albedos. Thus it is not necessary to compute the strict, exact albedo +values but must be always between 0 and 1. + +For metallic surfaces the albedo should be either the reflectivity at +normal incidence (e.g. from the artist friendly metallic Fresnel model) +or the average reflectivity; or if these are constant (not textured) or +unknown, the albedo can be simply 1 as well. + +The albedo for dielectric surfaces (e.g. glass) should be either 1 or, +if the surface is perfect specular (i.e. has a delta BSDF), the Fresnel +blend of the reflected and transmitted albedos. The latter usually works +better but only if it does not introduce too much noise or the albedo is +prefiltered. If noise is an issue, we recommend to split the path into a +reflected and a transmitted path at the first hit, and perhaps fall back +to an albedo of 1 for subsequent dielectric hits. The reflected albedo +in itself can be used for mirror-like surfaces as well. + +The albedo for layered surfaces can be computed as the weighted sum of +the albedos of the individual layers. Non-absorbing clear coat layers +can be simply ignored (or the albedo of the perfect specular reflection +can be used as well) but absorption should be taken into account. + +#### Normals + +The normal image should contain the shading normals of the surfaces +either in world-space or view-space. It is recommended to include normal +maps to preserve as much detail as possible. + +![](https://openimagedenoise.github.io/images/mazda_firsthit_512spp_normal.jpg) +Example normal image obtained using the first hit (the values are +actually in \[−1, 1\] but were mapped to \[0, 1\] for illustration +purposes). + +![](https://openimagedenoise.github.io/images/mazda_nondeltahit_512spp_normal.jpg) +Example normal image obtained using the first diffuse or glossy +(non-delta) hit. Note that the normals of perfect specular (delta) +transparent surfaces are computed as the Fresnel blend of the reflected +and transmitted +normals. + +Just like any other input image, the normal image should be anti-aliased +(i.e. by accumulating the normalized normals per pixel). The final +accumulated normals do not have to be normalized but must be in the +\[-1, 1\] range (i.e. normals mapped to \[0, 1\] are *not* acceptable +and must be remapped to \[−1, 1\]). + +Similar to the albedo, the normal can be stored for either the first or +a subsequent hit (if the first hit has a perfect specular/delta BSDF). + +#### Quality + +The filter supports setting an image quality mode, which determines +whether to favor quality, performance, or have a balanced solution +between the two. The supported quality modes are listed in the following +table. + +| Name | Description | +| :---------------------- | :----------------------------------------------------------------- | +| `OIDN_QUALITY_DEFAULT` | default quality | +| `OIDN_QUALITY_BALANCED` | balanced quality/performance (for interactive/real-time rendering) | +| `OIDN_QUALITY_HIGH` | high quality (for final-frame rendering); *default* | + +Supported image quality modes, i.e., valid constants of type +`OIDNQuality`. + +By default filtering is performed in high quality mode, which is +recommended for final-frame rendering. Using this setting the results +have the same high quality regardless of what kind of device (CPU or +GPU) is used. However, due to significant hardware architecture +differences between devices, there might be small numerical differences +between the produced outputs. + +The balanced quality mode is very close in image quality to the high +quality mode except that lower numerical precision is used, if this is +supported by the device. This may result in significantly higher +performance on some devices but on others there might be no difference +at all due to hardware specifics. This mode is recommended for +interactive and real-time rendering. + +Note that in balanced quality mode a higher variation in image quality +should be expected across devices. + +#### Weights + +Instead of using the built-in trained models for filtering, it is also +possible to specify user-trained models at runtime. This can be achieved +by passing the model *weights* blob corresponding to the specified set +of features and other filter parameters, produced by the included +training tool. See Section [Training](#training) for details. + +### RTLightmap + +The `RTLightmap` filter is a variant of the `RT` filter optimized for +denoising HDR and normalized directional (e.g. spherical harmonics) +lightmaps. It does not support LDR images. + +The filter can be created by passing `"RTLightmap"` to the +`oidnNewFilter` function as the filter type. The filter supports the +following parameters: + +| Type | Name | Default | Description | +| :------ | :-------------- | ---------: | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| `Image` | `color` | *required* | input beauty image (3 channels, HDR values in \[0, +∞), interpreted such that, after scaling with the `inputScale` parameter, a value of 1 corresponds to a luminance level of 100 cd/m²; directional values in \[-1, 1\]) | +| `Image` | `output` | *required* | output image (3 channels); can be one of the input images | +| `Bool` | `directional` | `false` | whether the input contains normalized coefficients (in \[-1, 1\]) of a directional lightmap (e.g. normalized L1 or higher spherical harmonics band with the L0 band divided out); if the range of the coefficients is different from \[-1, 1\], the `inputScale` parameter can be used to adjust the range without changing the stored values | +| `Float` | `inputScale` | NaN | scales input color values before filtering, without scaling the output too, which can be used to map color values to the expected range, e.g. for mapping HDR values to physical units (which affects the quality of the output but *not* the range of the output values); if set to NaN, the scale is computed implicitly for HDR images or set to 1 otherwise | +| `Int` | `quality` | high | image quality mode as an `OIDNQuality` value | +| `Data` | `weights` | *optional* | trained model weights blob | +| `Int` | `maxMemoryMB` | \-1 | if set to \>= 0, an attempt will be made to limit the memory usage below the specified amount in megabytes at the potential cost of slower performance but actual memory usage may be higher (the target may not be achievable or the device may not support this feature at all); otherwise memory usage will be limited to an unspecified device-dependent amount | +| `Int` | `tileAlignment` | *constant* | when manually denoising in tiles, the tile size and offsets should be multiples of this amount of pixels to avoid artifacts; when denoising HDR images `inputScale` *must* be set by the user to avoid seam artifacts | +| `Int` | `tileOverlap` | *constant* | when manually denoising in tiles, the tiles should overlap by this amount of pixels | + +Parameters supported by the `RTLightmap` filter. + +# Examples + +Intel Open Image Denoise ships with a couple of simple example +applications. + +## oidnDenoise + +`oidnDenoise` is a minimal working example demonstrating how to use +Intel Open Image Denoise, which can be found at `apps/oidnDenoise.cpp`. +It uses the C++11 convenience wrappers of the C99 API. + +This example is a simple command-line application that denoises the +provided image, which can optionally have auxiliary feature images as +well (e.g. albedo and normal). By default the images must be stored in +the [Portable FloatMap](http://www.pauldebevec.com/Research/HDR/PFM/) +(PFM) format, and the color values must be encoded in little-endian +format. To enable other image formats (e.g. OpenEXR, PNG) as well, the +project has to be rebuilt with OpenImageIO support enabled. + +Running `oidnDenoise` without any arguments or the `-h` argument will +bring up a list of command-line options. + +## oidnBenchmark + +`oidnBenchmark` is a basic command-line benchmarking application for +measuring denoising speed, which can be found at +`apps/oidnBenchmark.cpp`. + +Running `oidnBenchmark` with the `-h` argument will bring up a list of +command-line options. + +# Training + +The Intel Open Image Denoise source distribution includes a Python-based +neural network training toolkit (located in the `training` directory), +which can be used to train the denoising filter models with image +datasets provided by the user. This is an advanced feature of the +library which usage requires some background knowledge of machine +learning and basic familiarity with deep learning frameworks and +toolkits (e.g. PyTorch or TensorFlow, TensorBoard). + +The training toolkit consists of the following command-line scripts: + + - `preprocess.py`: Preprocesses training and validation datasets. + + - `train.py`: Trains a model using preprocessed datasets. + + - `infer.py`: Performs inference on a dataset using the specified + training result. + + - `export.py`: Exports a training result to the runtime model weights + format. + + - `find_lr.py`: Tool for finding the optimal minimum and maximum + learning rates. + + - `visualize.py`: Invokes TensorBoard for visualizing statistics of a + training result. + + - `split_exr.py`: Splits a multi-channel EXR image into multiple + feature images. + + - `convert_image.py`: Converts a feature image to a different image + format. + + - `compare_image.py`: Compares two feature images using the specified + quality metrics. + +## Prerequisites + +Before you can run the training toolkit you need the following +prerequisites: + + - Linux (other operating systems are currently not supported) + + - Python 3.7 or later + + - [PyTorch](https://pytorch.org/) 1.8 or later + + - [NumPy](https://numpy.org/) 1.19 or later + + - [OpenImageIO](http://openimageio.org/) 2.1 or later + + - [TensorBoard](https://www.tensorflow.org/tensorboard) 2.4 or later + (*optional*) + +## Devices + +Most scripts in the training toolkit support selecting what kind of +device (e.g. CPU, GPU) to use for the computations (`--device` or `-d` +option). If multiple devices of the same kind are available +(e.g. multiple GPUs), the user can specify which one of these to use +(`--device_id` or `-k` option). Additionally, some scripts, like +`train.py`, support data-parallel execution on multiple devices for +faster performance (`--num_devices` or `-n` option). + +## Datasets + +A dataset should consist of a collection of noisy and corresponding +noise-free reference images. It is possible to have more than one noisy +version of the same image in the dataset, e.g. rendered at different +samples per pixel and/or using different seeds. + +The training toolkit expects to have all datasets (e.g. training, +validation) in the same parent directory (e.g. `data`). Each dataset is +stored in its own subdirectory (e.g. `train`, `valid`), which can have +an arbitrary name. + +The images must be stored in [OpenEXR](https://www.openexr.com/) format +(`.exr` files), and the filenames must have a specific format but the +files can be stored in an arbitrary directory structure inside the +dataset directory. The only restriction is that all versions of an image +(noisy images and the reference image) must be located in the same +subdirectory. Each feature of an image (e.g. color, albedo) must be +stored in a separate image file, i.e. multi-channel EXR image files are +not supported. If you have multi-channel EXRs, you can split them into +separate images per feature using the included `split_exr.py` tool. + +An image filename must consist of a base name, a suffix with the number +of samples per pixel or whether it is the reference image +(e.g. `_0128spp`, `_ref`), the feature type extension (e.g. `.hdr`, +`.alb`), and the image format extension (`.exr`). The exact filename +format as a regular expression is the following: + +``` regexp +.+_([0-9]+(spp)?|ref|reference|gt|target)\.(hdr|ldr|sh1[xyz]|alb|nrm)\.exr +``` + +The number of samples per pixel should be padded with leading zeros to +have a fixed number of digits. If the reference image is not explicitly +named as such (i.e. has the number of samples instead), the image with +the most samples per pixel will be considered the reference. + +The following image features are supported: + +| Feature | Description | Channels | File extension | +| ------- | :---------------------------------------- | :----------- | :------------------------------------ | +| `hdr` | color (HDR) | 3 | `.hdr.exr` | +| `ldr` | color (LDR) | 3 | `.ldr.exr` | +| `sh1` | color (normalized L1 spherical harmonics) | 3 × 3 images | `.sh1x.exr`, `.sh1y.exr`, `.sh1z.exr` | +| `alb` | albedo | 3 | `.alb.exr` | +| `nrm` | normal | 3 | `.nrm.exr` | + +Image features supported by the training toolkit. + +The following directory tree demonstrates an example root dataset +directory (`data`) containing one dataset (`rt_train`) with HDR color +and albedo feature images: + + data + `-- rt_train + |-- scene1 + | |-- view1_0001.alb.exr + | |-- view1_0001.hdr.exr + | |-- view1_0004.alb.exr + | |-- view1_0004.hdr.exr + | |-- view1_8192.alb.exr + | |-- view1_8192.hdr.exr + | |-- view2_0001.alb.exr + | |-- view2_0001.hdr.exr + | |-- view2_8192.alb.exr + | `-- view2_8192.hdr.exr + |-- scene2_000008spp.alb.exr + |-- scene2_000008spp.hdr.exr + |-- scene2_000064spp.alb.exr + |-- scene2_000064spp.hdr.exr + |-- scene2_reference.alb.exr + `-- scene2_reference.hdr.exr + +## Preprocessing (preprocess.py) + +Training and validation datasets can be used only after preprocessing +them using the `preprocess.py` script. This will convert the specified +training (`--train_data` or `-t` option) and validation datasets +(`--valid_data` or `-v` option) located in the root dataset directory +(`--data_dir` or `-D` option) to a format that can be loaded more +efficiently during training. All preprocessed datasets will be stored in +a root preprocessed dataset directory (`--preproc_dir` or `-P` option). + +The preprocessing script requires the set of image features to include +in the preprocessed dataset as command-line arguments. Only these +specified features will be available for training but it is not required +to use all of them at the same time. Thus, a single preprocessed dataset +can be reused for training multiple models with different combinations +of the preprocessed features. + +By default, all input features are assumed to be noisy, including the +auxiliary features (e.g. albedo, normal), each having versions at +different samples per pixel. However, it is also possible to train with +noise-free auxiliary features, in which case the reference auxiliary +features are used instead of the various noisy ones (`--clean_aux` +option). + +Preprocessing also depends on the filter that will be trained +(e.g. determines which HDR/LDR transfer function has to be used), which +should be also specified (`--filter` or `-f` option). The alternative is +to manually specify the transfer function (`--transfer` or `-x` option) +and other filter-specific parameters, which could be useful for training +custom filters. + +For example, to preprocess the training and validation datasets +(`rt_train` and `rt_valid`) with HDR color, albedo, and normal image +features, for training the `RT` filter, the following command can be +used: + + ./preprocess.py hdr alb nrm --filter RT --train_data rt_train --valid_data rt_valid + +It is possible to preprocess the same dataset multiple times, with +possibly different combinations of features and options. The training +script will use the most suitable and most recent preprocessed version +depending on the training parameters. + +For more details about using the preprocessing script, including other +options, please have a look at the help message: + + ./preprocess.py -h + +## Training (train.py) + +The filters require separate trained models for each supported +combination of input features. Thus, depending on which combinations of +features the user wants to support for a particular filter, one or more +models have to be trained. + +After preprocessing the datasets, it is possible to start training a +model using the `train.py` script. Similar to the preprocessing script, +the input features must be specified (could be a subset of the +preprocessed features), and the dataset names, directory paths, and the +filter can be also passed. + +The tool will produce a training *result*, the name of which can be +either specified (`--result` or `-r` option) or automatically generated +(by default). Each result is stored in its own subdirectory, and these +are located in a common parent directory (`--results_dir` or `-R` +option). If a training result already exists, the tool will resume +training that result from the latest checkpoint. + +The default training hyperparameters should work reasonably well in +general, but some adjustments might be necessary for certain datasets to +attain optimal performance, most importantly: the number of epochs +(`--num_epochs` or `-e` option), the global mini-batch size +(`--batch_size` or `-b` option), and the learning rate. The training +tool uses a one-cycle learning rate schedule with cosine annealing, +which can be configured by setting the base learning rate +(`--learning_rate` or `--lr` option), the maximum learning rate +(`--max_learning_rate` or `--max_lr` option), and the percentage of the +cycle spent increasing the learning rate (`--learning_rate_warmup` or +`--lr_warmup` option). + +Example usage: + + ./train.py hdr alb --filter RT --train_data rt_train --valid_data rt_valid --result rt_hdr_alb + +For finding the optimal learning rate range, we recommend using the +included `find_lr.py` script, which trains one epoch using an increasing +learning rate and logs the resulting losses in a comma-separated values +(CSV) file. Plotting the loss curve can show when the model starts to +learn (the base learning rate) and when it starts to diverge (the +maximum learning rate). + +The model is evaluated with the validation dataset at regular intervals +(`--num_valid_epochs` option), and checkpoints are also regularly +created (`--num_save_epochs` option) to save training progress. Also, +some statistics are logged (e.g. training and validation losses, +learning rate) per epoch, which can be later visualized with TensorBoard +by running the `visualize.py` script, e.g.: + + ./visualize.py --result rt_hdr_alb + +Training is performed with mixed precision (FP16 and FP32) by default, +if it supported by the hardware, which makes training faster and use +less memory. However, in some rare cases this might cause some +convergence issues. The training precision can be manually set to FP32 +if necessary (`--precision` or `-p` option). + +## Inference (infer.py) + +A training result can be tested by performing inference on an image +dataset (`--input_data` or `-i` option) using the `infer.py` script. The +dataset does *not* have to be preprocessed. In addition to the result to +use, it is possible to specify which checkpoint to load as well (`-e` or +`--num_epochs` option). By default the latest checkpoint is loaded. + +The tool saves the output images in a separate directory (`--output_dir` +or `-O` option) in the requested formats (`--format` or `-F` option). It +also evaluates a set of image quality metrics (`--metric` or `-M` +option), e.g. PSNR, SSIM, for images that have reference images +available. All metrics are computed in tonemapped non-linear sRGB space. +Thus, HDR images are first tonemapped (with Naughty Dog’s Filmic +Tonemapper from John Hable’s *Uncharted 2: HDR Lighting* presentation) +and converted to sRGB before evaluating the metrics. + +Example usage: + + ./infer.py --result rt_hdr_alb --input_data rt_test --format exr png --metric ssim + +The inference tool supports prefiltering of auxiliary features as well, +which can be performed by specifying the list of training results for +each feature to prefilter (`--aux_results` or `-a` option). This is +primarily useful for evaluating the quality of models trained with clean +auxiliary features. + +## Exporting Results (export.py) + +The training result produced by the `train.py` script cannot be +immediately used by the main library. It has to be first exported to the +runtime model weights format, a *Tensor Archive* (TZA) file. Running the +`export.py` script for a training result (and optionally a checkpoint +epoch) will create a binary `.tza` file in the directory of the result, +which can be either used at runtime through the API or it can be +included in the library build by replacing one of the built-in weights +files. + +Example usage: + + ./export.py --result rt_hdr_alb + +## Image Conversion and Comparison + +In addition to the already mentioned `split_exr.py` script, the toolkit +contains a few other image utilities as well. + +`convert_image.py` converts a feature image to a different image format +(and/or a different feature, e.g. HDR color to LDR), performing +tonemapping and other transforms as well if needed. For HDR images the +exposure can be adjusted by passing a linear exposure scale +(`--exposure` or `-E` option). Example usage: + + ./convert_image.py view1_0004.hdr.exr view1_0004.png --exposure 2.5 + +The `compare_image.py` script compares two feature images (preferably +having the dataset filename format to correctly detect the feature) +using the specified image quality metrics, similar to the `infer.py` +tool. Example usage: + + ./compare_image.py view1_0004.hdr.exr view1_8192.hdr.exr --exposure 2.5 --metric mse ssim + +1. For example, if Intel Open Image Denoise is in `~/Projects/oidn`, + ISPC will also be searched in `~/Projects/ispc-v1.14.1-linux` diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/readme.pdf b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/readme.pdf new file mode 100644 index 0000000..1bc5c1e Binary files /dev/null and b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/readme.pdf differ diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-DPCPP.txt b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-DPCPP.txt new file mode 100644 index 0000000..0e55972 --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-DPCPP.txt @@ -0,0 +1,110 @@ + +The oneAPI DPC++ Compiler can be found here: + + https://github.com/intel/llvm + +It uses various components with following licenses: + + https://github.com/intel/llvm/blob/master/flang/LICENSE.TXT + https://github.com/intel/llvm/blob/master/compiler-rt/LICENSE.TXT + https://github.com/intel/llvm/blob/master/mlir/LICENSE.TXT + https://github.com/intel/llvm/blob/master/libclc/LICENSE.TXT + https://github.com/intel/llvm/blob/master/libcxxabi/LICENSE.TXT + https://github.com/intel/llvm/blob/master/lld/LICENSE.TXT + https://github.com/intel/llvm/blob/master/cross-project-tests/debuginfo-tests/dexter/LICENSE.txt + https://github.com/intel/llvm/blob/master/libc/LICENSE.TXT + https://github.com/intel/llvm/blob/master/clang-tools-extra/LICENSE.TXT + https://github.com/intel/llvm/blob/master/clang-tools-extra/clang-tidy/cert/LICENSE.TXT + https://github.com/intel/llvm/blob/master/clang-tools-extra/clang-tidy/hicpp/LICENSE.TXT + https://github.com/intel/llvm/blob/master/lldb/LICENSE.TXT + https://github.com/intel/llvm/blob/master/lldb/third_party/Python/module/ptyprocess-0.6.0/LICENSE + https://github.com/intel/llvm/blob/master/lldb/third_party/Python/module/six/LICENSE + https://github.com/intel/llvm/blob/master/lldb/third_party/Python/module/pexpect-4.6/LICENSE + https://github.com/intel/llvm/blob/master/polly/LICENSE.TXT + https://github.com/intel/llvm/blob/master/polly/lib/External/isl/LICENSE + https://github.com/intel/llvm/blob/master/polly/lib/External/isl/imath/LICENSE + https://github.com/intel/llvm/blob/master/polly/tools/GPURuntime/LICENSE.TXT + https://github.com/intel/llvm/blob/master/sycl/LICENSE.TXT + https://github.com/intel/llvm/blob/master/llvm-spirv/LICENSE.TXT + https://github.com/intel/llvm/blob/master/bolt/LICENSE.TXT + https://github.com/intel/llvm/blob/master/pstl/LICENSE.TXT + https://github.com/intel/llvm/blob/master/clang/LICENSE.TXT + https://github.com/intel/llvm/blob/master/llvm/utils/lit/LICENSE.TXT + https://github.com/intel/llvm/blob/master/llvm/utils/unittest/googletest/LICENSE.TXT + https://github.com/intel/llvm/blob/master/llvm/utils/unittest/googlemock/LICENSE.txt + https://github.com/intel/llvm/blob/master/llvm/LICENSE.TXT + https://github.com/intel/llvm/blob/master/llvm/include/llvm/Support/LICENSE.TXT + https://github.com/intel/llvm/blob/master/llvm/lib/Support/BLAKE3/LICENSE + https://github.com/intel/llvm/blob/master/llvm/test/YAMLParser/LICENSE.txt + https://github.com/intel/llvm/blob/master/libunwind/LICENSE.TXT + https://github.com/intel/llvm/blob/master/openmp/LICENSE.TXT + https://github.com/intel/llvm/blob/master/openmp/runtime/src/thirdparty/ittnotify/LICENSE.txt + https://github.com/intel/llvm/blob/master/third-party/benchmark/LICENSE + https://github.com/intel/llvm/blob/master/libcxx/LICENSE.TXT + +The following people and companies contributed to the LLVM project: + + https://github.com/intel/llvm/blob/master/compiler-rt/CREDITS.TXT + https://github.com/intel/llvm/blob/master/libclc/CREDITS.TXT + https://github.com/intel/llvm/blob/master/libcxxabi/CREDITS.TXT + https://github.com/intel/llvm/blob/master/polly/CREDITS.txt + https://github.com/intel/llvm/blob/master/pstl/CREDITS.txt + https://github.com/intel/llvm/blob/master/llvm/CREDITS.TXT + https://github.com/intel/llvm/blob/master/openmp/CREDITS.txt + https://github.com/intel/llvm/blob/master/libcxx/CREDITS.TXT + +============================================================================== +Software from third parties included in the LLVM Project: +============================================================================== +The LLVM Project contains third party software which is under different license +terms. All such code will be identified clearly using at least one of two +mechanisms: +1) It will be in a separate directory tree with its own `LICENSE.txt` or + `LICENSE` file at the top containing the specific license and restrictions + which apply to that software, or +2) It will contain specific license and restriction terms at the top of every + file. + +============================================================================== +Legacy LLVM License (https://llvm.org/docs/DeveloperPolicy.html#legacy): +============================================================================== +University of Illinois/NCSA +Open Source License + +Copyright (c) 2003-2020 University of Illinois at Urbana-Champaign. +All rights reserved. + +Developed by: + + LLVM Team + + University of Illinois at Urbana-Champaign + + http://llvm.org + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal with +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimers. + + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimers in the + documentation and/or other materials provided with the distribution. + + * Neither the names of the LLVM Team, University of Illinois at + Urbana-Champaign, nor the names of its contributors may be used to + endorse or promote products derived from this Software without specific + prior written permission. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS +FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS WITH THE +SOFTWARE. diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-oneDNN.txt b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-oneDNN.txt new file mode 100644 index 0000000..1b8bbcc --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-oneDNN.txt @@ -0,0 +1,583 @@ +oneAPI Deep Neural Network Library (oneDNN) Third Party Programs File + +This file contains the list of third party software ("third party programs") +contained in the Intel software and their required notices and/or license +terms. This third party software, even if included with the distribution of +the Intel software, may be governed by separate license terms, including +without limitation, third party license terms, other Intel software license +terms, and open source software license terms. These separate license terms +govern your use of the third party programs as set forth in in the +"THIRD-PARTY-PROGRAMS" file. + +Third party programs and their corresponding required notices and/or license +terms are listed below. + +-------------------------------------------------------------------------------- +1. XByak (src/cpu/xbyak/) +Copyright (c) 2007 MITSUNARI Shigeo +All rights reserved. + +3-Clause BSD License + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +Redistributions of source code must retain the above copyright notice, this +list of conditions and the following disclaimer. +Redistributions in binary form must reproduce the above copyright notice, +this list of conditions and the following disclaimer in the documentation +and/or other materials provided with the distribution. +Neither the name of the copyright owner nor the names of its contributors may +be used to endorse or promote products derived from this software without +specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF +THE POSSIBILITY OF SUCH DAMAGE. + + +ソースコード形式かバイナリ形式か、変更するかしないかを問わず、以下の条件を満た +す場合に限り、再頒布および使用が許可されます。 + +ソースコードを再頒布する場合、上記の著作権表示、本条件一覧、および下記免責条項 +を含めること。 +バイナリ形式で再頒布する場合、頒布物に付属のドキュメント等の資料に、上記の著作 +権表示、本条件一覧、および下記免責条項を含めること。 +書面による特別の許可なしに、本ソフトウェアから派生した製品の宣伝または販売促進 +に、著作権者の名前またはコントリビューターの名前を使用してはならない。 +本ソフトウェアは、著作権者およびコントリビューターによって「現状のまま」提供さ +れており、明示黙示を問わず、商業的な使用可能性、および特定の目的に対する適合性 +に関する暗黙の保証も含め、またそれに限定されない、いかなる保証もありません。 +著作権者もコントリビューターも、事由のいかんを問わず、 損害発生の原因いかんを +問わず、かつ責任の根拠が契約であるか厳格責任であるか(過失その他の)不法行為で +あるかを問わず、仮にそのような損害が発生する可能性を知らされていたとしても、 +本ソフトウェアの使用によって発生した(代替品または代用サービスの調達、使用の +喪失、データの喪失、利益の喪失、業務の中断も含め、またそれに限定されない)直接 +損害、間接損害、偶発的な損害、特別損害、懲罰的損害、または結果損害について、 +一切責任を負わないものとします。 + +-------------------------------------------------------------------------------- +2. Googletest (tests/gtests/gtest/) +Copyright 2005, Google Inc. +Copyright 2006, Google Inc. +Copyright 2007, Google Inc. +Copyright 2008, Google Inc. +Copyright 2015, Google Inc. +All rights reserved. + +3-Clause BSD License + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + + * Redistributions of source code must retain the above copyright +notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above +copyright notice, this list of conditions and the following disclaimer +in the documentation and/or other materials provided with the +distribution. + * Neither the name of Google Inc. nor the names of its +contributors may be used to endorse or promote products derived from +this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +-------------------------------------------------------------------------------- +3. Instrumentation and Tracing Technology API (src/common/ittnotify/) +Copyright (c) 2011, Intel Corporation. All rights reserved. +Copyright (c) 2005-2014 Intel Corporation. All rights reserved. + +3-Clause BSD License + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + +3. Neither the name of Intel Corporation nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +-------------------------------------------------------------------------------- +4. CMake (cmake/FindOpenCL.cmake, cmake/FindBLAS.cmake, cmake/FindACL.cmake) +CMake - Cross Platform Makefile Generator +Copyright 2000-2020 Kitware, Inc. and Contributors +All rights reserved. + +3-Clause BSD License + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + +* Neither the name of Kitware, Inc. nor the names of Contributors + may be used to endorse or promote products derived from this + software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +------------------------------------------------------------------------------ + +The following individuals and institutions are among the Contributors: + +* Aaron C. Meadows +* Adriaan de Groot +* Aleksey Avdeev +* Alexander Neundorf +* Alexander Smorkalov +* Alexey Sokolov +* Alex Merry +* Alex Turbov +* Andreas Pakulat +* Andreas Schneider +* André Rigland Brodtkorb +* Axel Huebl, Helmholtz-Zentrum Dresden - Rossendorf +* Benjamin Eikel +* Bjoern Ricks +* Brad Hards +* Christopher Harvey +* Christoph Grüninger +* Clement Creusot +* Daniel Blezek +* Daniel Pfeifer +* Enrico Scholz +* Eran Ifrah +* Esben Mose Hansen, Ange Optimization ApS +* Geoffrey Viola +* Google Inc +* Gregor Jasny +* Helio Chissini de Castro +* Ilya Lavrenov +* Insight Software Consortium +* Jan Woetzel +* Julien Schueller +* Kelly Thompson +* Konstantin Podsvirov +* Laurent Montel +* Mario Bensi +* Martin Gräßlin +* Mathieu Malaterre +* Matthaeus G. Chajdas +* Matthias Kretz +* Matthias Maennich +* Michael Hirsch, Ph.D. +* Michael Stürmer +* Miguel A. Figueroa-Villanueva +* Mike Jackson +* Mike McQuaid +* Nicolas Bock +* Nicolas Despres +* Nikita Krupen'ko +* NVIDIA Corporation +* OpenGamma Ltd. +* Patrick Stotko +* Per Øyvind Karlsen +* Peter Collingbourne +* Petr Gotthard +* Philip Lowman +* Philippe Proulx +* Raffi Enficiaud, Max Planck Society +* Raumfeld +* Roger Leigh +* Rolf Eike Beer +* Roman Donchenko +* Roman Kharitonov +* Ruslan Baratov +* Sebastian Holtermann +* Stephen Kelly +* Sylvain Joubert +* The Qt Company Ltd. +* Thomas Sondergaard +* Tobias Hunger +* Todd Gamblin +* Tristan Carel +* University of Dundee +* Vadim Zhukov +* Will Dicharry + +See version control history for details of individual contributions. + +The above copyright and license notice applies to distributions of +CMake in source and binary form. Third-party software packages supplied +with CMake under compatible licenses provide their own copyright notices +documented in corresponding subdirectories or source files. + +------------------------------------------------------------------------------ + +CMake was initially developed by Kitware with the following sponsorship: + + * National Library of Medicine at the National Institutes of Health + as part of the Insight Segmentation and Registration Toolkit (ITK). + + * US National Labs (Los Alamos, Livermore, Sandia) ASC Parallel + Visualization Initiative. + + * National Alliance for Medical Image Computing (NAMIC) is funded by the + National Institutes of Health through the NIH Roadmap for Medical Research, + Grant U54 EB005149. + + * Kitware, Inc. + +-------------------------------------------------------------------------------- +5. Xbyak_aarch64 (src/cpu/aarch64/xbyak_aarch64/) +Copyright 2019-2020 FUJITSU LIMITED + +Apache License, Version 2.0 + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. + + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + +-------------------------------------------------------------------------------- +6. Boost C++ Libraries (src/common/primitive_hashing.hpp) +Copyright 2005-2014 Daniel James. + +Boost Software License - Version 1.0 - August 17th, 2003 + +Permission is hereby granted, free of charge, to any person or organization +obtaining a copy of the software and accompanying documentation covered by +this license (the "Software") to use, reproduce, display, distribute, +execute, and transmit the Software, and to prepare derivative works of the +Software, and to permit third-parties to whom the Software is furnished to +do so, all subject to the following: + +The copyright notices in the Software and this entire statement, including +the above license grant, this restriction and the following disclaimer, +must be included in all copies of the Software, in whole or in part, and +all derivative works of the Software, unless such copies or derivative +works are solely in the form of machine-executable object code generated by +a source language processor. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT +SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE +FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, +ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. + +-------------------------------------------------------------------------------- +7. Intel(R) Graphics Compute Runtime for oneAPI Level Zero and OpenCL(TM) +Driver (src/gpu/jit/ngen/npack/{elf_structs,hash}.hpp) +Copyright (c) 2018 Intel Corporation + +Intel(R) Graphics Compiler (src/gpu/jit/ngen/npack/neo_structs.hpp) +Copyright (c) 2019 Intel Corporation + +oneAPI Level Zero (src/sycl/level_zero) +Copyright (C) 2019-2021 Intel Corporation + +Doxyrest toolkit (doc/doxyrest/*) +Copyright (c) 2016, Tibbo Technology Inc +Copyright (c) 2016, Vladimir Gladkov +Copyright (c) 2016, Doxyrest maintainers + +MIT License + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +8. Sphinx (doc/sphinx/conf/py) +Copyright (c) 2007-2021 by the Sphinx team (see AUTHORS file). +All rights reserved. + +2-Clause BSD License + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are +met: + +* Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + +* Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +-------------------------------------------------------------------------------- +9. Intel(R) Metrics Discovery Application Programming Interface (src/gpu/ocl/mdapi/metrics_discovery_api.h) +MIT License + +Copyright (c) 2019, Intel Corporation + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the "Software"), +to deal in the Software without restriction, including without limitation +the rights to use, copy, modify, merge, publish, distribute, sublicense, +and/or sell copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included +in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +IN THE SOFTWARE. diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-oneTBB.txt b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-oneTBB.txt new file mode 100644 index 0000000..b555450 --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs-oneTBB.txt @@ -0,0 +1,411 @@ +oneAPI Threading Building Blocks (oneTBB) Third Party Programs File + +This file contains the list of third party software ("third party programs") +contained in the Intel software and their required notices and/or license terms. +This third party software, even if included with the distribution of the Intel +software, may be governed by separate license terms, including without limitation, +third party license terms, other Intel software license terms, and open source +software license terms. These separate license terms govern your use of the third +party programs as set forth in the "third-party-programs.txt" or other similarlynamed text file. + +The third party programs and their corresponding required notices and/or license +terms are listed below. +_______________________________________________________________________________________________________ + +1. Intel(R) Instrumentation and Tracing Technology (ITT) + Copyright (c) 2022 Intel Corporation. All rights reserved. + + Redistribution and use in source and binary forms, with or without modification, + are permitted provided that the following conditions are met: + + 1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + 3. Neither the name of the copyright holder nor the names of its contributors may be + used to endorse or promote products derived from this software + without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + SUCH DAMAGE. + +_______________________________________________________________________________________________________ + +2. ActiveState Thread pool with same API as (multi) processing.Pool (Python recipe): + Copyright (c) 2008,2016 david decotigny (this file) + Copyright (c) 2006-2008, R Oudkerk (multiprocessing.Pool) + + Portable Hardware Locality (hwloc) + Copyright (c) 2004-2006 The Trustees of Indiana University and Indiana University Research and Technology Corporation. All rights reserved. + Copyright (c) 2004-2005 The University of Tennessee and The University of Tennessee Research Foundation. All rights reserved. + Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, University of Stuttgart. All rights reserved. + Copyright (c) 2004-2005 The Regents of the University of California. All rights reserved. + Copyright (c) 2009 CNRS + Copyright (c) 2009-2016 Inria. All rights reserved. + Copyright (c) 2009-2015 Universit Bordeaux + Copyright (c) 2009-2015 Cisco Systems, Inc. All rights reserved. + Copyright (c) 2009-2012 Oracle and/or its affiliates. All rights reserved. + Copyright (c) 2010 IBM + Copyright (c) 2010 Jirka Hladky + Copyright (c) 2012 Aleksej Saushev, The NetBSD Foundation + Copyright (c) 2012 Blue Brain Project, EPFL. All rights reserved. + Copyright (c) 2013-2014 University of Wisconsin-La Crosse. All rights reserved. + Copyright (c) 2015 Research Organization for Information Science and Technology (RIST). All rights reserved. + Copyright (c) 2015-2016 Intel, Inc. All rights reserved. + + BSD 3-clause "New" or "Revised" License + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + + 1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + 3. Neither the name of author nor the names of any contributors may be + used to endorse or promote products derived from this software + without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS "AS IS" AND + ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + SUCH DAMAGE. +_______________________________________________________________________________________________________ + +3. gperftools: Copyright (c) 2011, Google Inc. + + Tachyon: Copyright (c) 1994-2008 John E. Stone. All rights reserved. + + BSD 3-Clause "New" or "Revised" License + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are + met: + + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following disclaimer + in the documentation and/or other materials provided with the + distribution. + * Neither the name of Google Inc. nor the names of its + contributors may be used to endorse or promote products derived from + this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +_______________________________________________________________________________________________________ + +4. Mateusz Kwiatkowski Workaround for bug 62258 in libstdc++ + + GPL 3.0 with GCC Runtime Library Exception 3.1 + + GNU GENERAL PUBLIC LICENSE + + Version 3, 29 June 2007 + + Copyright (c) 2007 Free Software Foundation, Inc. + + Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. + + Preamble + The GNU General Public License is a free, copyleft license for software and other kinds of works. + + The licenses for most software and other practical works are designed to take away your freedom to share and change the works. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change all versions of a program--to make sure it remains free software for all its users. We, the Free Software Foundation, use the GNU General Public License for most of our software; it applies also to any other work released this way by its authors. You can apply it to your programs, too. + + When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for them if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs, and that you know you can do these things. + + To protect your rights, we need to prevent others from denying you these rights or asking you to surrender the rights. Therefore, you have certain responsibilities if you distribute copies of the software, or if you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether gratis or for a fee, you must pass on to the recipients the same freedoms that you received. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. + + Developers that use the GNU GPL protect your rights with two steps: (1) assert copyright on the software, and (2) offer you this License giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains that there is no warranty for this free software. For both users' and authors' sake, the GPL requires that modified versions be marked as changed, so that their problems will not be attributed erroneously to authors of previous versions. + + Some devices are designed to deny users access to install or run modified versions of the software inside them, although the manufacturer can do so. This is fundamentally incompatible with the aim of protecting users' freedom to change the software. The systematic pattern of such abuse occurs in the area of products for individuals to use, which is precisely where it is most unacceptable. Therefore, we have designed this version of the GPL to prohibit the practice for those products. If such problems arise substantially in other domains, we stand ready to extend this provision to those domains in future versions of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. States should not allow patents to restrict development and use of software on general-purpose computers, but in those that do, we wish to avoid the special danger that patents applied to a free program could make it effectively proprietary. To prevent this, the GPL assures that patents cannot be used to render the program non-free. + + The precise terms and conditions for copying, distribution and modification follow. + + TERMS AND CONDITIONS + 0. Definitions. + "This License" refers to version 3 of the GNU General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this License. Each licensee is addressed as "you". "Licensees" and "recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work in a fashion requiring copyright permission, other than the making of an exact copy. The resulting work is called a "modified version" of the earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based on the Program. + + To "propagate" a work means to do anything with it that, without permission, would make you directly or secondarily liable for infringement under applicable copyright law, except executing it on a computer or modifying a private copy. Propagation includes copying, distribution (with or without modification), making available to the public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other parties to make or receive copies. Mere interaction with a user through a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" to the extent that it includes a convenient and prominently visible feature that (1) displays an appropriate copyright notice, and (2) tells the user that there is no warranty for the work (except to the extent that warranties are provided), that licensees may convey the work under this License, and how to view a copy of this License. If the interface presents a list of user commands or options, such as a menu, a prominent item in the list meets this criterion. + + 1. Source Code. + The "source code" for a work means the preferred form of the work for making modifications to it. "Object code" means any non-source form of a work. + + A "Standard Interface" means an interface that either is an official standard defined by a recognized standards body, or, in the case of interfaces specified for a particular programming language, one that is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other than the work as a whole, that (a) is included in the normal form of packaging a Major Component, but which is not part of that Major Component, and (b) serves only to enable use of the work with that Major Component, or to implement a Standard Interface for which an implementation is available to the public in source code form. A "Major Component", in this context, means a major essential component (kernel, window system, and so on) of the specific operating system (if any) on which the executable work runs, or a compiler used to produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all the source code needed to generate, install, and (for an executable work) run the object code and to modify the work, including scripts to control those activities. However, it does not include the work's System Libraries, or general-purpose tools or generally available free programs which are used unmodified in performing those activities but which are not part of the work. For example, Corresponding Source includes interface definition files associated with source files for the work, and the source code for shared libraries and dynamically linked subprograms that the work is specifically designed to require, such as by intimate data communication or control flow between those subprograms and other parts of the work. + + The Corresponding Source need not include anything that users can regenerate automatically from other parts of the Corresponding Source. + + The Corresponding Source for a work in source code form is that same work. + + 2. Basic Permissions. + All rights granted under this License are granted for the term of copyright on the Program, and are irrevocable provided the stated conditions are met. This License explicitly affirms your unlimited permission to run the unmodified Program. The output from running a covered work is covered by this License only if the output, given its content, constitutes a covered work. This License acknowledges your rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not convey, without conditions so long as your license otherwise remains in force. You may convey covered works to others for the sole purpose of having them make modifications exclusively for you, or provide you with facilities for running those works, provided that you comply with the terms of this License in conveying all material for which you do not control copyright. Those thus making or running the covered works for you must do so exclusively on your behalf, under your direction and control, on terms that prohibit them from making any copies of your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under the conditions stated below. Sublicensing is not allowed; section 10 makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + No covered work shall be deemed part of an effective technological measure under any applicable law fulfilling obligations under article 11 of the WIPO copyright treaty adopted on 20 December 1996, or similar laws prohibiting or restricting circumvention of such measures. + + When you convey a covered work, you waive any legal power to forbid circumvention of technological measures to the extent such circumvention is effected by exercising rights under this License with respect to the covered work, and you disclaim any intention to limit operation or modification of the work as a means of enforcing, against the work's users, your or third parties' legal rights to forbid circumvention of technological measures. + + 4. Conveying Verbatim Copies. + You may convey verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice; keep intact all notices stating that this License and any non-permissive terms added in accord with section 7 apply to the code; keep intact all notices of the absence of any warranty; and give all recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + You may convey a work based on the Program, or the modifications to produce it from the Program, in the form of source code under the terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified it, and giving a relevant date. + b) The work must carry prominent notices stating that it is released under this License and any conditions added under section 7. This requirement modifies the requirement in section 4 to "keep intact all notices". + c) You must license the entire work, as a whole, under this License to anyone who comes into possession of a copy. This License will therefore apply, along with any applicable section 7 additional terms, to the whole of the work, and all its parts, regardless of how they are packaged. This License gives no permission to license the work in any other way, but it does not invalidate such permission if you have separately received it. + d) If the work has interactive user interfaces, each must display Appropriate Legal Notices; however, if the Program has interactive interfaces that do not display Appropriate Legal Notices, your work need not make them do so. + A compilation of a covered work with other separate and independent works, which are not by their nature extensions of the covered work, and which are not combined with it such as to form a larger program, in or on a volume of a storage or distribution medium, is called an "aggregate" if the compilation and its resulting copyright are not used to limit the access or legal rights of the compilation's users beyond what the individual works permit. Inclusion of a covered work in an aggregate does not cause this License to apply to the other parts of the aggregate. + + 6. Conveying Non-Source Forms. + You may convey a covered work in object code form under the terms of sections 4 and 5, provided that you also convey the machine-readable Corresponding Source under the terms of this License, in one of these ways: + + a) Convey the object code in, or embodied in, a physical product (including a physical distribution medium), accompanied by the Corresponding Source fixed on a durable physical medium customarily used for software interchange. + b) Convey the object code in, or embodied in, a physical product (including a physical distribution medium), accompanied by a written offer, valid for at least three years and valid for as long as you offer spare parts or customer support for that product model, to give anyone who possesses the object code either (1) a copy of the Corresponding Source for all the software in the product that is covered by this License, on a durable physical medium customarily used for software interchange, for a price no more than your reasonable cost of physically performing this conveying of source, or (2) access to copy the Corresponding Source from a network server at no charge. + c) Convey individual copies of the object code with a copy of the written offer to provide the Corresponding Source. This alternative is allowed only occasionally and noncommercially, and only if you received the object code with such an offer, in accord with subsection 6b. + d) Convey the object code by offering access from a designated place (gratis or for a charge), and offer equivalent access to the Corresponding Source in the same way through the same place at no further charge. You need not require recipients to copy the Corresponding Source along with the object code. If the place to copy the object code is a network server, the Corresponding Source may be on a different server (operated by you or a third party) that supports equivalent copying facilities, provided you maintain clear directions next to the object code saying where to find the Corresponding Source. Regardless of what server hosts the Corresponding Source, you remain obligated to ensure that it is available for as long as needed to satisfy these requirements. + e) Convey the object code using peer-to-peer transmission, provided you inform other peers where the object code and Corresponding Source of the work are being offered to the general public at no charge under subsection 6d. + A separable portion of the object code, whose source code is excluded from the Corresponding Source as a System Library, need not be included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any tangible personal property which is normally used for personal, family, or household purposes, or (2) anything designed or sold for incorporation into a dwelling. In determining whether a product is a consumer product, doubtful cases shall be resolved in favor of coverage. For a particular product received by a particular user, "normally used" refers to a typical or common use of that class of product, regardless of the status of the particular user or of the way in which the particular user actually uses, or expects or is expected to use, the product. A product is a consumer product regardless of whether the product has substantial commercial, industrial or non-consumer uses, unless such uses represent the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, procedures, authorization keys, or other information required to install and execute modified versions of a covered work in that User Product from a modified version of its Corresponding Source. The information must suffice to ensure that the continued functioning of the modified object code is in no case prevented or interfered with solely because modification has been made. + + If you convey an object code work under this section in, or with, or specifically for use in, a User Product, and the conveying occurs as part of a transaction in which the right of possession and use of the User Product is transferred to the recipient in perpetuity or for a fixed term (regardless of how the transaction is characterized), the Corresponding Source conveyed under this section must be accompanied by the Installation Information. But this requirement does not apply if neither you nor any third party retains the ability to install modified object code on the User Product (for example, the work has been installed in ROM). + + The requirement to provide Installation Information does not include a requirement to continue to provide support service, warranty, or updates for a work that has been modified or installed by the recipient, or for the User Product in which it has been modified or installed. Access to a network may be denied when the modification itself materially and adversely affects the operation of the network or violates the rules and protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, in accord with this section must be in a format that is publicly documented (and with an implementation available to the public in source code form), and must require no special password or key for unpacking, reading or copying. + + 7. Additional Terms. + "Additional permissions" are terms that supplement the terms of this License by making exceptions from one or more of its conditions. Additional permissions that are applicable to the entire Program shall be treated as though they were included in this License, to the extent that they are valid under applicable law. If additional permissions apply only to part of the Program, that part may be used separately under those permissions, but the entire Program remains governed by this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option remove any additional permissions from that copy, or from any part of it. (Additional permissions may be written to require their own removal in certain cases when you modify the work.) You may place additional permissions on material, added by you to a covered work, for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you add to a covered work, you may (if authorized by the copyright holders of that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the terms of sections 15 and 16 of this License; or + b) Requiring preservation of specified reasonable legal notices or author attributions in that material or in the Appropriate Legal Notices displayed by works containing it; or + c) Prohibiting misrepresentation of the origin of that material, or requiring that modified versions of such material be marked in reasonable ways as different from the original version; or + d) Limiting the use for publicity purposes of names of licensors or authors of the material; or + e) Declining to grant rights under trademark law for use of some trade names, trademarks, or service marks; or + f) Requiring indemnification of licensors and authors of that material by anyone who conveys the material (or modified versions of it) with contractual assumptions of liability to the recipient, for any liability that these contractual assumptions directly impose on those licensors and authors. + All other non-permissive additional terms are considered "further restrictions" within the meaning of section 10. If the Program as you received it, or any part of it, contains a notice stating that it is governed by this License along with a term that is a further restriction, you may remove that term. If a license document contains a further restriction but permits relicensing or conveying under this License, you may add to a covered work material governed by the terms of that license document, provided that the further restriction does not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you must place, in the relevant source files, a statement of the additional terms that apply to those files, or a notice indicating where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the form of a separately written license, or stated as exceptions; the above requirements apply either way. + + 8. Termination. + You may not propagate or modify a covered work except as expressly provided under this License. Any attempt otherwise to propagate or modify it is void, and will automatically terminate your rights under this License (including any patent licenses granted under the third paragraph of section 11). + + However, if you cease all violation of this License, then your license from a particular copyright holder is reinstated (a) provisionally, unless and until the copyright holder explicitly and finally terminates your license, and (b) permanently, if the copyright holder fails to notify you of the violation by some reasonable means prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is reinstated permanently if the copyright holder notifies you of the violation by some reasonable means, this is the first time you have received notice of violation of this License (for any work) from that copyright holder, and you cure the violation prior to 30 days after your receipt of the notice. + + Termination of your rights under this section does not terminate the licenses of parties who have received copies or rights from you under this License. If your rights have been terminated and not permanently reinstated, you do not qualify to receive new licenses for the same material under section 10. + + 9. Acceptance Not Required for Having Copies. + You are not required to accept this License in order to receive or run a copy of the Program. Ancillary propagation of a covered work occurring solely as a consequence of using peer-to-peer transmission to receive a copy likewise does not require acceptance. However, nothing other than this License grants you permission to propagate or modify any covered work. These actions infringe copyright if you do not accept this License. Therefore, by modifying or propagating a covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + Each time you convey a covered work, the recipient automatically receives a license from the original licensors, to run, modify and propagate that work, subject to this License. You are not responsible for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an organization, or substantially all assets of one, or subdividing an organization, or merging organizations. If propagation of a covered work results from an entity transaction, each party to that transaction who receives a copy of the work also receives whatever licenses to the work the party's predecessor in interest had or could give under the previous paragraph, plus a right to possession of the Corresponding Source of the work from the predecessor in interest, if the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the rights granted or affirmed under this License. For example, you may not impose a license fee, royalty, or other charge for exercise of rights granted under this License, and you may not initiate litigation (including a cross-claim or counterclaim in a lawsuit) alleging that any patent claim is infringed by making, using, selling, offering for sale, or importing the Program or any portion of it. + + 11. Patents. + A "contributor" is a copyright holder who authorizes use under this License of the Program or a work on which the Program is based. The work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims owned or controlled by the contributor, whether already acquired or hereafter acquired, that would be infringed by some manner, permitted by this License, of making, using, or selling its contributor version, but do not include claims that would be infringed only as a consequence of further modification of the contributor version. For purposes of this definition, "control" includes the right to grant patent sublicenses in a manner consistent with the requirements of this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free patent license under the contributor's essential patent claims, to make, use, sell, offer for sale, import and otherwise run, modify and propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express agreement or commitment, however denominated, not to enforce a patent (such as an express permission to practice a patent or covenant not to sue for patent infringement). To "grant" such a patent license to a party means to make such an agreement or commitment not to enforce a patent against the party. + + If you convey a covered work, knowingly relying on a patent license, and the Corresponding Source of the work is not available for anyone to copy, free of charge and under the terms of this License, through a publicly available network server or other readily accessible means, then you must either (1) cause the Corresponding Source to be so available, or (2) arrange to deprive yourself of the benefit of the patent license for this particular work, or (3) arrange, in a manner consistent with the requirements of this License, to extend the patent license to downstream recipients. "Knowingly relying" means you have actual knowledge that, but for the patent license, your conveying the covered work in a country, or your recipient's use of the covered work in a country, would infringe one or more identifiable patents in that country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or arrangement, you convey, or propagate by procuring conveyance of, a covered work, and grant a patent license to some of the parties receiving the covered work authorizing them to use, propagate, modify or convey a specific copy of the covered work, then the patent license you grant is automatically extended to all recipients of the covered work and works based on it. + + A patent license is "discriminatory" if it does not include within the scope of its coverage, prohibits the exercise of, or is conditioned on the non-exercise of one or more of the rights that are specifically granted under this License. You may not convey a covered work if you are a party to an arrangement with a third party that is in the business of distributing software, under which you make payment to the third party based on the extent of your activity of conveying the work, and under which the third party grants, to any of the parties who would receive the covered work from you, a discriminatory patent license (a) in connection with copies of the covered work conveyed by you (or copies made from those copies), or (b) primarily for and in connection with specific products or compilations that contain the covered work, unless you entered into that arrangement, or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting any implied license or other defenses to infringement that may otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + If conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot convey a covered work so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not convey it at all. For example, if you agree to terms that obligate you to collect a royalty for further conveying from those to whom you convey the Program, the only way you could satisfy both those terms and this License would be to refrain entirely from conveying the Program. + + 13. Use with the GNU Affero General Public License. + Notwithstanding any other provision of this License, you have permission to link or combine any covered work with a work licensed under version 3 of the GNU Affero General Public License into a single combined work, and to convey the resulting work. The terms of this License will continue to apply to the part which is the covered work, but the special requirements of the GNU Affero General Public License, section 13, concerning interaction through a network will apply to the combination as such. + + 14. Revised Versions of this License. + The Free Software Foundation may publish revised and/or new versions of the GNU General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the Program specifies that a certain numbered version of the GNU General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that numbered version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of the GNU General Public License, you may choose any version ever published by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future versions of the GNU General Public License can be used, that proxy's public statement of acceptance of a version permanently authorizes you to choose that version for the Program. + + Later license versions may give you additional or different permissions. However, no additional obligations are imposed on any author or copyright holder as a result of your choosing to follow a later version. + + 15. Disclaimer of Warranty. + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + If the disclaimer of warranty and limitation of liability provided above cannot be given local legal effect according to their terms, reviewing courts shall apply local law that most closely approximates an absolute waiver of all civil liability in connection with the Program, unless a warranty or assumption of liability accompanies a copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively state the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short notice like this when it starts in an interactive mode: + + Copyright (C) + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, your program's commands might be different; for a GUI interface, you would use an "about box". + + You should also get your employer (if you work as a programmer) or school, if any, to sign a "copyright disclaimer" for the program, if necessary. For more information on this, and how to apply and follow the GNU GPL, see . + + The GNU General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Lesser General Public License instead of this License. But first, please read . + + + GCC RUNTIME LIBRARY EXCEPTION + + Version 3.1, 31 March 2009 + + Copyright (c) 2009 Free Software Foundation, Inc. + + Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. + + This GCC Runtime Library Exception ("Exception") is an additional permission under section 7 of the GNU General Public License, version 3 ("GPLv3"). It applies to a given file (the "Runtime Library") that bears a notice placed by the copyright holder of the file stating that the file is governed by GPLv3 along with this Exception. + + When you use GCC to compile a program, GCC may combine portions of certain GCC header files and runtime libraries with the compiled program. The purpose of this Exception is to allow compilation of non-GPL (including proprietary) programs to use, in this way, the header files and runtime libraries covered by this Exception. + + 0. Definitions. + A file is an "Independent Module" if it either requires the Runtime Library for execution after a Compilation Process, or makes use of an interface provided by the Runtime Library, but is not otherwise based on the Runtime Library. + + "GCC" means a version of the GNU Compiler Collection, with or without modifications, governed by version 3 (or a specified later version) of the GNU General Public License (GPL) with the option of using any subsequent versions published by the FSF. + + "GPL-compatible Software" is software whose conditions of propagation, modification and use would permit combination with GCC in accord with the license of GCC. + + "Target Code" refers to output from any compiler for a real or virtual target processor architecture, in executable form or suitable for input to an assembler, loader, linker and/or execution phase. Notwithstanding that, Target Code does not include data in any format that is used as a compiler intermediate representation, or used for producing a compiler intermediate representation. + + The "Compilation Process" transforms code entirely represented in non-intermediate languages designed for human-written code, and/or in Java Virtual Machine byte code, into Target Code. Thus, for example, use of source code generators and preprocessors need not be considered part of the Compilation Process, since the Compilation Process can be understood as starting with the output of the generators or preprocessors. + + A Compilation Process is "Eligible" if it is done using GCC, alone or with other GPL-compatible software, or if it is done without using any work based on GCC. For example, using non-GPL-compatible Software to optimize any GCC intermediate representations would not qualify as an Eligible Compilation Process. + + 1. Grant of Additional Permission. + You have permission to propagate a work of Target Code formed by combining the Runtime Library with Independent Modules, even if such propagation would otherwise violate the terms of GPLv3, provided that all Target Code was generated by Eligible Compilation Processes. You may then convey such a combination under terms of your choice, consistent with the licensing of the Independent Modules. + + 2. No Weakening of GCC Copyleft. + The availability of this Exception does not imply any general presumption that third-party software is unaffected by the copyleft requirements of the license of GCC. + +_______________________________________________________________________________________________________ + +5. Doctest + + Copyright (c) 2016-2021 Viktor Kirilov + + The MIT License (MIT) + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in all + copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + SOFTWARE. +_______________________________________________________________________________________________________ + +*Other names and brands may be claimed as the property of others. diff --git a/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs.txt b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs.txt new file mode 100644 index 0000000..f3d76ae --- /dev/null +++ b/thirdparty/OpenImageDenoise/share/doc/OpenImageDenoise/third-party-programs.txt @@ -0,0 +1,645 @@ +Intel(R) Open Image Denoise Third Party Programs File + +This file contains the list of third party software ("third party programs") +contained in the Intel software and their required notices and/or license +terms. This third party software, even if included with the distribution of the +Intel software, may be governed by separate license terms, including without +limitation, third party license terms, other Intel software license terms, and +open source software license terms. These separate license terms govern your use +of the third party programs as set forth in the "third-party-programs.txt" or +other similarly named text file. + +Third party programs and their corresponding required notices and/or license +terms are listed below. + +-------------------------------------------------------------------------------- + +1. Intel(R) oneAPI Deep Neural Network Library (oneDNN) + Copyright 2016-2023 Intel Corporation + + Intel(R) oneAPI Threading Building Blocks (oneTBB) + Copyright 2005-2023 Intel Corporation + + Intel® Embree (snippets) + Copyright Intel Corporation + + Intel® OSPRay (snippets) + Copyright Intel Corporation + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + +-------------------------------------------------------------------------------- + +2. PyTorch + + From PyTorch: + + Copyright (c) 2016- Facebook, Inc (Adam Paszke) + Copyright (c) 2014- Facebook, Inc (Soumith Chintala) + Copyright (c) 2011-2014 Idiap Research Institute (Ronan Collobert) + Copyright (c) 2012-2014 Deepmind Technologies (Koray Kavukcuoglu) + Copyright (c) 2011-2012 NEC Laboratories America (Koray Kavukcuoglu) + Copyright (c) 2011-2013 NYU (Clement Farabet) + Copyright (c) 2006-2010 NEC Laboratories America (Ronan Collobert, Leon Bottou, Iain Melvin, Jason Weston) + Copyright (c) 2006 Idiap Research Institute (Samy Bengio) + Copyright (c) 2001-2004 Idiap Research Institute (Ronan Collobert, Samy Bengio, Johnny Mariethoz) + + From Caffe2: + + Copyright (c) 2016-present, Facebook Inc. All rights reserved. + + All contributions by Facebook: + Copyright (c) 2016 Facebook Inc. + + All contributions by Google: + Copyright (c) 2015 Google Inc. + All rights reserved. + + All contributions by Yangqing Jia: + Copyright (c) 2015 Yangqing Jia + All rights reserved. + + All contributions from Caffe: + Copyright(c) 2013, 2014, 2015, the respective contributors + All rights reserved. + + All other contributions: + Copyright(c) 2015, 2016 the respective contributors + All rights reserved. + + Caffe2 uses a copyright model similar to Caffe: each contributor holds + copyright over their contributions to Caffe2. The project versioning records + all such contribution and copyright details. If a contributor wants to further + mark their specific copyright on a particular contribution, they should + indicate their copyright solely in the commit message of the change when it is + committed. + + All rights reserved. + + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + +3. Neither the names of Facebook, Deepmind Technologies, NYU, NEC Laboratories America + and IDIAP Research Institute nor the names of its contributors may be + used to endorse or promote products derived from this software without + specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. + +-------------------------------------------------------------------------------- + +3. pytorch-msssim + Copyright (c) 2019 Gongfan Fang + + ROCmSoftwarePlatform/composable_kernel + Copyright (c) 2018- , Advanced Micro Devices, Inc. (Chao Liu, Jing Zhang) + Copyright (c) 2019- , Advanced Micro Devices, Inc. (Letao Qin, Qianfeng Zhang, Liang Huang, Shaojie Wang) + Copyright (c) 2022- , Advanced Micro Devices, Inc. (Anthony Chang, Chunyu Lai, Illia Silin, Adam Osewski, Poyen Chen, Jehandad Khan) + Copyright (c) 2019-2021, Advanced Micro Devices, Inc. (Hanwen Chang) + Copyright (c) 2019-2020, Advanced Micro Devices, Inc. (Tejash Shah) + Copyright (c) 2020 , Advanced Micro Devices, Inc. (Xiaoyan Zhou) + Copyright (c) 2021-2022, Advanced Micro Devices, Inc. (Jianfeng Yan) + Copyright (c) 2018-2022, Advanced Micro Devices, Inc. All rights reserved. + +MIT License + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +-------------------------------------------------------------------------------- + +4. Catch2 + Copyright (c) 2021 Two Blue Cubes Ltd. All rights reserved. + +Boost Software License - Version 1.0 - August 17th, 2003 + +Permission is hereby granted, free of charge, to any person or organization +obtaining a copy of the software and accompanying documentation covered by +this license (the "Software") to use, reproduce, display, distribute, +execute, and transmit the Software, and to prepare derivative works of the +Software, and to permit third-parties to whom the Software is furnished to +do so, all subject to the following: + +The copyright notices in the Software and this entire statement, including +the above license grant, this restriction and the following disclaimer, +must be included in all copies of the Software, in whole or in part, and +all derivative works of the Software, unless such copies or derivative +works are solely in the form of machine-executable object code generated by +a source language processor. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT +SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE +FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, +ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. + +-------------------------------------------------------------------------------- + +5. CUTLASS + Copyright (c) 2017 - 2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved. + +SPDX-License-Identifier: BSD-3-Clause + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this +list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright notice, +this list of conditions and the following disclaimer in the documentation +and/or other materials provided with the distribution. + +3. Neither the name of the copyright holder nor the names of its +contributors may be used to endorse or promote products derived from +this software without specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +-------------------------------------------------------------------------------- + +6. oneAPI Data Parallel C++ Compiler + Copyright Intel Corporation + +============================================================================== +The LLVM Project is under the Apache License v2.0 with LLVM Exceptions: +============================================================================== + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + + +---- LLVM Exceptions to the Apache 2.0 License ---- + +As an exception, if, as a result of your compiling your source code, portions +of this Software are embedded into an Object form of such source code, you +may redistribute such embedded portions in such Object form without complying +with the conditions of Sections 4(a), 4(b) and 4(d) of the License. + +In addition, if you combine or link compiled forms of this Software with +software that is licensed under the GPLv2 ("Combined Software") and if a +court of competent jurisdiction determines that the patent provision (Section +3), the indemnity provision (Section 9) or other Section of the License +conflicts with the conditions of the GPLv2, you may retroactively and +prospectively choose to deem waived or otherwise exclude such Section(s) of +the License, but only in their entirety and only with respect to the Combined +Software. + +-------------------------------------------------------------------------------- + +The following third party programs have their own third party programs. These +additional third party program files are as follows: + +1. Intel(R) oneAPI Deep Neural Network Library (oneDNN) + ./third-party-programs-oneDNN.txt + +2. Intel(R) oneAPI Threading Building Blocks (oneTBB) + ./third-party-programs-oneTBB.txt + +3. oneAPI DPC++ Compiler + ./third-party-programs-DPCPP.txt + +-------------------------------------------------------------------------------- \ No newline at end of file