Overview

Request 3793 (accepted)

Update to version 2.4

Submit package home:enzokiel:branches:Essentials / x265 to package Essentials / x265

x265.changes Changed
x
 
1
@@ -1,4 +1,44 @@
2
 -------------------------------------------------------------------
3
+Thu Apr 27 14:15:13 UTC 2017 - joerg.lorenzen@ki.tng.de
4
+
5
+- Update to version 2.4
6
+  Encoder enhancements
7
+  * HDR10+ supported. Dynamic metadata may be either supplied as a
8
+    bitstream via the userSEI field of x265_picture, or as a json
9
+    jile that can be parsed by x265 and inserted into the bitstream;
10
+    use --dhdr10-info to specify json file name, and --dhdr10-opt
11
+    to enable optimization of inserting tone-map information only
12
+    at IDR frames, or when the tone map information changes.
13
+  * Lambda tables for 8, 10, and 12-bit encoding revised, resulting
14
+    in significant enhancement to subjective visual quality.
15
+  * Enhanced HDR10 encoding with HDR-specific QP optimzations for
16
+    chroma, and luma planes of WCG content enabled; use --hdr-opt
17
+    to activate.
18
+  * Ability to accept analysis information from other previous
19
+    encodes (that may or may not be x265), and selectively reuse
20
+    and refine analysis for encoding subsequent passes enabled with
21
+    the --refine-level option.
22
+  * Slow and veryslow presets receive a 20% speed boost at
23
+    iso-quality by enabling the --limit-tu option.
24
+  * The bitrate target for x265 can now be dynamically reconfigured
25
+    via the reconfigure API.
26
+  * Performance optimized SAO algorithm introduced via the
27
+    --limit-sao option; seeing 10% speed benefits at faster presets.
28
+  API changes
29
+  * x265_reconfigure API now also accepts rate-control parameters
30
+    for dynamic reconfiguration.
31
+  * Several additions to data fields in x265_analysis to support
32
+    --refine-level: see x265.h for more details.
33
+  Bug fixes
34
+  * Avoid negative offsets in x265 lambda2 table with SAO enabled.
35
+  * Fix mingw32 build error.
36
+  * Seek now enabled for pipe input, in addition to file-based input.
37
+  * Fix issue of statically linking core-utils not working in linux.
38
+  * Fix visual artifacts with --multi-pass-opt-distortion with VBV.
39
+  * Fix bufferFill stats reported in csv.
40
+- soname bump to 116.
41
+
42
+-------------------------------------------------------------------
43
 Fri Feb 24 14:03:24 UTC 2017 - ismail@i10z.com
44
 
45
 - Update to version 2.3
46
x265.spec Changed
14
 
1
@@ -1,10 +1,10 @@
2
 # based on the spec file from https://build.opensuse.org/package/view_file/home:Simmphonie/libx265/
3
 
4
 Name:           x265
5
-%define soname  110
6
+%define soname  116
7
 %define libname lib%{name}
8
 %define libsoname %{libname}-%{soname}
9
-Version:        2.3
10
+Version:        2.4
11
 Release:        0
12
 License:        GPL-2.0+
13
 Summary:        A free h265/HEVC encoder - encoder binary
14
baselibs.conf Changed
4
 
1
@@ -1,1 +1,1 @@
2
-libx265-110
3
+libx265-116
4
x265_2.3.tar.gz/.hg_archival.txt -> x265_2.4.tar.gz/.hg_archival.txt Changed
8
 
1
@@ -1,4 +1,4 @@
2
 repo: 09fe40627f03a0f9c3e6ac78b22ac93da23f9fdf
3
-node: 3037c1448549ca920967831482c653e5892fa8ed
4
+node: e7a4dd48293b7956d4a20df257d23904cc78e376
5
 branch: stable
6
-tag: 2.3
7
+tag: 2.4
8
x265_2.3.tar.gz/.hgtags -> x265_2.4.tar.gz/.hgtags Changed
6
 
1
@@ -21,3 +21,4 @@
2
 960c9991d0dcf46559c32e070418d3cbb7e8aa2f 2.0
3
 981e3bfef16a997bce6f46ce1b15631a0e234747 2.1
4
 be14a7e9755e54f0fd34911c72bdfa66981220bc 2.2
5
+3037c1448549ca920967831482c653e5892fa8ed 2.3
6
x265_2.3.tar.gz/doc/reST/cli.rst -> x265_2.4.tar.gz/doc/reST/cli.rst Changed
67
 
1
@@ -816,6 +816,25 @@
2
    Specify a filename for analysis data (see :option:`--analysis-mode`)
3
    If no filename is specified, x265_analysis.dat is used.
4
 
5
+.. option:: --refine-level <1..10>
6
+
7
+   Amount of information stored/reused in :option:`--analysis-mode` is distributed across levels.
8
+   Higher the value, higher the information stored/reused, faster the encode. Default 5.
9
+
10
+   Note that --refine-level must be paired with analysis-mode.
11
+
12
+   +--------+-----------------------------------------+
13
+   | Level  | Description                             |
14
+   +========+=========================================+
15
+   | 1      | Lookahead information                   |
16
+   +--------+-----------------------------------------+
17
+   | 2 to 4 | Level 1 + intra/inter modes, ref's      |
18
+   +--------+-----------------------------------------+
19
+   | 5 to 9 | Level 2 + rect-amp                      |
20
+   +--------+-----------------------------------------+
21
+   | 10     | Level 5 + Full CU analysis-info         |
22
+   +--------+-----------------------------------------+
23
+
24
 Options which affect the transform unit quad-tree, sometimes referred to
25
 as the residual quad-tree (RQT).
26
 
27
@@ -1671,9 +1690,15 @@
28
    disabled, SAO analysis skips the right/bottom boundary areas.
29
    Default disabled
30
 
31
+.. option:: --limit-sao, --no-limit-sao
32
+
33
+   Limit SAO filter computation by early terminating SAO process based
34
+   on inter prediction mode, CTU spatial-domain correlations, and relations
35
+   between luma and chroma.
36
+   Default disabled
37
+
38
 VUI (Video Usability Information) options
39
 =========================================
40
-
41
 x265 emits a VUI with only the timing info by default. If the SAR is
42
 specified (or read from a Y4M header) it is also included.  All other
43
 VUI fields must be manually specified.
44
@@ -1845,6 +1870,22 @@
45
    automatically when :option`--master-display` or :option`--max-cll` is
46
    specified. Useful when there is a desire to signal 0 values for max-cll
47
    and max-fall. Default disabled.
48
+   
49
+.. option:: --hdr-opt, --no-hdr-opt
50
+
51
+   Add luma and chroma offsets for HDR/WCG content.
52
+   Input video should be 10 bit 4:2:0. Applicable for HDR content.
53
+   Default disabled. **Experimental Feature**
54
+   
55
+.. option:: --dhdr10-info <filename>
56
+
57
+   Inserts tone mapping information as an SEI message.
58
+   
59
+.. option:: --dhdr10-opt, --no-dhdr10-opt
60
+
61
+   Limits the frames for which tone mapping information is inserted as 
62
+   SEI message. Inserts SEI only for IDR frames and for frames where tone
63
+   mapping information has changed.
64
 
65
 .. option:: --min-luma <integer>
66
 
67
x265_2.3.tar.gz/doc/reST/presets.rst -> x265_2.4.tar.gz/doc/reST/presets.rst Changed
10
 
1
@@ -95,6 +95,8 @@
2
 +-----------------+-----+-----+-----+-----+-----+-----+------+------+------+------+
3
 | tu-inter        |  1  |  1  |  1  |   1 |   1 |   1 |   1  |   2  |   3  |  4   |
4
 +-----------------+-----+-----+-----+-----+-----+-----+------+------+------+------+
5
+| limit-tu        |  0  |  0  |  0  |   0 |   0 |   0 |   0  |   4  |   4  |  0   |
6
++-----------------+-----+-----+-----+-----+-----+-----+------+------+------+------+
7
 
8
 .. _tunings:
9
 
10
x265_2.3.tar.gz/doc/reST/releasenotes.rst -> x265_2.4.tar.gz/doc/reST/releasenotes.rst Changed
40
 
1
@@ -2,6 +2,38 @@
2
 Release Notes
3
 *************
4
 
5
+Release Notes
6
+*************
7
+
8
+Version 2.4
9
+===========
10
+
11
+Release date - 22nd April, 2017.
12
+
13
+Encoder enhancements
14
+--------------------
15
+1. HDR10+ supported. Dynamic metadata may be either supplied as a bitstream via the userSEI field of x265_picture, or as a json jile that can be parsed by x265 and inserted into the bitstream; use :option:`--dhdr10-info` to specify json file name, and :option:`--dhdr10-opt` to enable optimization of inserting tone-map information only at IDR frames, or when the tone map information changes.
16
+2. Lambda tables for 8, 10, and 12-bit encoding revised, resulting in significant enhancement to subjective  visual quality.
17
+3. Enhanced HDR10 encoding with HDR-specific QP optimzations for chroma, and luma planes of WCG content enabled; use :option:`--hdr-opt` to activate.
18
+4. Ability to accept analysis information from other previous encodes (that may or may not be x265), and selectively reuse and refine analysis for encoding subsequent passes enabled with the :option:`--refine-level` option. 
19
+5. Slow and veryslow presets receive a 20% speed boost at iso-quality by enabling the :option:`--limit-tu` option.
20
+6. The bitrate target for x265 can now be dynamically reconfigured via the reconfigure API.
21
+7. Performance optimized SAO algorithm introduced via the :option:`--limit-sao` option; seeing 10% speed benefits at faster presets.
22
+
23
+API changes
24
+-----------
25
+1. x265_reconfigure API now also accepts rate-control parameters for dynamic reconfiguration.
26
+2. Several additions to data fields in x265_analysis to support :option:`--refine-level`: see x265.h for more details.
27
+
28
+Bug fixes
29
+---------
30
+1. Avoid negative offsets in x265 lambda2 table with SAO enabled.
31
+2. Fix mingw32 build error.
32
+3. Seek now enabled for pipe input, in addition to file-based input
33
+4. Fix issue of statically linking core-utils not working in linux.
34
+5. Fix visual artifacts with :option:`--multi-pass-opt-distortion` with VBV.
35
+6. Fix bufferFill stats reported in csv.
36
+
37
 Version 2.3
38
 ===========
39
 
40
x265_2.3.tar.gz/source/CMakeLists.txt -> x265_2.4.tar.gz/source/CMakeLists.txt Changed
89
 
1
@@ -29,7 +29,7 @@
2
 option(STATIC_LINK_CRT "Statically link C runtime for release builds" OFF)
3
 mark_as_advanced(FPROFILE_USE FPROFILE_GENERATE NATIVE_BUILD)
4
 # X265_BUILD must be incremented each time the public API is changed
5
-set(X265_BUILD 110)
6
+set(X265_BUILD 116)
7
 configure_file("${PROJECT_SOURCE_DIR}/x265.def.in"
8
                "${PROJECT_BINARY_DIR}/x265.def")
9
 configure_file("${PROJECT_SOURCE_DIR}/x265_config.h.in"
10
@@ -255,7 +255,7 @@
11
     endif(FPROFILE_USE)
12
     if(STATIC_LINK_CRT)
13
         add_definitions(-static)
14
-        list(APPEND LINKER_OPTIONS "-static")
15
+        list(APPEND LINKER_OPTIONS "-static-libgcc")
16
     endif(STATIC_LINK_CRT)
17
     check_cxx_compiler_flag(-Wno-strict-overflow CC_HAS_NO_STRICT_OVERFLOW)
18
     check_cxx_compiler_flag(-Wno-narrowing CC_HAS_NO_NARROWING) 
19
@@ -363,6 +363,13 @@
20
 else(HIGH_BIT_DEPTH)
21
     add_definitions(-DHIGH_BIT_DEPTH=0 -DX265_DEPTH=8)
22
 endif(HIGH_BIT_DEPTH)
23
+# this option is to enable the inclusion of dynamic HDR10 library to the libx265 compilation
24
+option(ENABLE_DYNAMIC_HDR10 "Enable dynamic HDR10 compilation" OFF)
25
+if (ENABLE_DYNAMIC_HDR10)
26
+    add_subdirectory(dynamicHDR10)
27
+    include_directories(dynamicHDR10)
28
+    add_definitions(-DENABLE_DYNAMIC_HDR10)
29
+endif(ENABLE_DYNAMIC_HDR10)
30
 
31
 # this option can only be used when linking multiple libx265 libraries
32
 # together, and some alternate API access method is implemented.
33
@@ -502,9 +509,12 @@
34
         endforeach()
35
     endif()
36
 endif()
37
-
38
 source_group(ASM FILES ${ASM_SRCS})
39
-add_library(x265-static STATIC $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> ${ASM_OBJS} ${ASM_SRCS})
40
+if(ENABLE_DYNAMIC_HDR10)
41
+    add_library(x265-static STATIC $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> $<TARGET_OBJECTS:dynamicHDR10> ${ASM_OBJS} ${ASM_SRCS})
42
+else()
43
+    add_library(x265-static STATIC $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> ${ASM_OBJS} ${ASM_SRCS})
44
+endif()
45
 if(NOT MSVC)
46
     set_target_properties(x265-static PROPERTIES OUTPUT_NAME x265)
47
 endif()
48
@@ -535,11 +545,16 @@
49
 if(NOT (MSVC_IDE OR XCODE))
50
     add_custom_target(clean-generated COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_SOURCE_DIR}/cmake/clean-generated.cmake)
51
 endif()
52
-
53
 option(ENABLE_SHARED "Build shared library" ON)
54
 if(ENABLE_SHARED)
55
-    add_library(x265-shared SHARED "${PROJECT_BINARY_DIR}/x265.def" ${ASM_OBJS}
56
-                ${X265_RC_FILE} $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common>)
57
+
58
+    if(ENABLE_DYNAMIC_HDR10)
59
+        add_library(x265-shared SHARED "${PROJECT_BINARY_DIR}/x265.def" ${ASM_OBJS}
60
+                    ${X265_RC_FILE} $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> $<TARGET_OBJECTS:dynamicHDR10>)
61
+    else()
62
+        add_library(x265-shared SHARED "${PROJECT_BINARY_DIR}/x265.def" ${ASM_OBJS}
63
+                   ${X265_RC_FILE} $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common>)
64
+    endif()
65
     if(EXTRA_LIB)
66
         target_link_libraries(x265-shared ${EXTRA_LIB})
67
     endif()
68
@@ -629,12 +644,17 @@
69
     if(WIN32)
70
         set(ExportDefs "${PROJECT_BINARY_DIR}/x265.def")
71
     endif(WIN32)
72
-
73
     if(XCODE)
74
         # Xcode seems unable to link the CLI with libs, so link as one targget
75
+        if(ENABLE_DYNAMIC_HDR10)
76
         add_executable(cli ../COPYING ${InputFiles} ${OutputFiles} ${GETOPT}
77
-                       x265.cpp x265.h x265cli.h x265-extras.h x265-extras.cpp
78
-                       $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> ${ASM_OBJS} ${ASM_SRCS})
79
+                        x265.cpp x265.h x265cli.h x265-extras.h x265-extras.cpp
80
+                        $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> $<TARGET_OBJECTS:dynamicHDR10> ${ASM_OBJS} ${ASM_SRCS})
81
+        else()
82
+            add_executable(cli ../COPYING ${InputFiles} ${OutputFiles} ${GETOPT}
83
+                        x265.cpp x265.h x265cli.h x265-extras.h x265-extras.cpp
84
+                        $<TARGET_OBJECTS:encoder> $<TARGET_OBJECTS:common> ${ASM_OBJS} ${ASM_SRCS})
85
+        endif()
86
     else()
87
         add_executable(cli ../COPYING ${InputFiles} ${OutputFiles} ${GETOPT} ${X265_RC_FILE}
88
                        ${ExportDefs} x265.cpp x265.h x265cli.h x265-extras.h x265-extras.cpp)
89
x265_2.3.tar.gz/source/cmake/FindNuma.cmake -> x265_2.4.tar.gz/source/cmake/FindNuma.cmake Changed
10
 
1
@@ -14,7 +14,7 @@
2
 #   NUMA_LIBRARY
3
 #     Points to the libnuma that can be passed to target_link_libararies.
4
 #
5
-# Copyright (c) 2015 Steve Borho
6
+# Copyright (c) 2013-2017 MulticoreWare, Inc
7
 
8
 include(FindPackageHandleStandardArgs)
9
 
10
x265_2.3.tar.gz/source/cmake/FindVLD.cmake -> x265_2.4.tar.gz/source/cmake/FindVLD.cmake Changed
10
 
1
@@ -23,7 +23,7 @@
2
 #     target_link_libararies.
3
 #
4
 #
5
-# Copyright (c) 2012 Sergiu Dotenco
6
+# Copyright (c) 2013-2017 MulticoreWare, Inc
7
 #
8
 # Permission is hereby granted, free of charge, to any person obtaining a copy
9
 # of this software and associated documentation files (the "Software"), to deal
10
x265_2.3.tar.gz/source/cmake/FindVtune.cmake -> x265_2.4.tar.gz/source/cmake/FindVtune.cmake Changed
10
 
1
@@ -5,7 +5,7 @@
2
 #   VTUNE_INCLUDE_DIR: Points to the vtunes include dir
3
 #   VTUNE_LIBRARY_DIR: Points to the directory with libraries
4
 #
5
-# Copyright (c) 2015 Pradeep Ramachandran
6
+# Copyright (c) 2013-2017 MulticoreWare, Inc
7
 
8
 include(FindPackageHandleStandardArgs)
9
 
10
x265_2.3.tar.gz/source/common/arm/asm-primitives.cpp -> x265_2.4.tar.gz/source/common/arm/asm-primitives.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/asm.S -> x265_2.4.tar.gz/source/common/arm/asm.S Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /*****************************************************************************
3
  * asm.S: arm utility macros
4
  *****************************************************************************
5
- * Copyright (C) 2016 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Mans Rullgard <mans@mansr.com>
9
  *          David Conrad <lessen42@gmail.com>
10
x265_2.3.tar.gz/source/common/arm/blockcopy8.S -> x265_2.4.tar.gz/source/common/arm/blockcopy8.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Radhakrishnan VR <radhakrishnan@multicorewareinc.com>
7
  * 
8
x265_2.3.tar.gz/source/common/arm/blockcopy8.h -> x265_2.4.tar.gz/source/common/arm/blockcopy8.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/arm/cpu-a.S -> x265_2.4.tar.gz/source/common/arm/cpu-a.S Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /*****************************************************************************
3
  * cpu-a.S: arm cpu detection
4
  *****************************************************************************
5
- * Copyright (C) 2016 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: David Conrad <lessen42@gmail.com>
9
  *          Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
10
x265_2.3.tar.gz/source/common/arm/dct-a.S -> x265_2.4.tar.gz/source/common/arm/dct-a.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Min Chen <chenm003@163.com>
7
  * 
8
x265_2.3.tar.gz/source/common/arm/dct8.h -> x265_2.4.tar.gz/source/common/arm/dct8.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Min Chen <chenm003@163.com>
7
  *          Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/intrapred.h -> x265_2.4.tar.gz/source/common/arm/intrapred.h Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /*****************************************************************************
3
  * intrapred.h: Intra Prediction metrics
4
  *****************************************************************************
5
- * Copyright (C) 2003-2013 x264 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Min Chen <chenm003@163.com> <min.chen@multicorewareinc.com>
9
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
10
x265_2.3.tar.gz/source/common/arm/ipfilter8.S -> x265_2.4.tar.gz/source/common/arm/ipfilter8.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Dnyaneshwar G <dnyaneshwar@multicorewareinc.com>
7
  *          Radhakrishnan VR <radhakrishnan@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/ipfilter8.h -> x265_2.4.tar.gz/source/common/arm/ipfilter8.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/loopfilter.h -> x265_2.4.tar.gz/source/common/arm/loopfilter.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
7
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/mc-a.S -> x265_2.4.tar.gz/source/common/arm/mc-a.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
7
  *          Radhakrishnan <radhakrishnan@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/mc.h -> x265_2.4.tar.gz/source/common/arm/mc.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/arm/pixel-util.S -> x265_2.4.tar.gz/source/common/arm/pixel-util.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Dnyaneshwar G <dnyaneshwar@multicorewareinc.com>
7
  *          Radhakrishnan VR <radhakrishnan@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/arm/pixel-util.h -> x265_2.4.tar.gz/source/common/arm/pixel-util.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
 ;*          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/arm/pixel.h -> x265_2.4.tar.gz/source/common/arm/pixel.h Changed
12
 
1
@@ -1,8 +1,8 @@
2
 /*****************************************************************************
3
  * pixel.h: x86 pixel metrics
4
  *****************************************************************************
5
- * Copyright (C) 2003-2013 x264 project
6
- * Copyright (C) 2013-2016 x265 project
7
+ * Copyright (C) 2003-2017 x265 project
8
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
9
  *
10
  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
11
  *          Loren Merritt <lorenm@u.washington.edu>
12
x265_2.3.tar.gz/source/common/arm/sad-a.S -> x265_2.4.tar.gz/source/common/arm/sad-a.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: David Conrad <lessen42@gmail.com>
7
  *          Janne Grunau <janne-x264@jannau.net>
8
x265_2.3.tar.gz/source/common/arm/ssd-a.S -> x265_2.4.tar.gz/source/common/arm/ssd-a.S Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2016 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Dnyaneshwar G <dnyaneshwar@multicorewareinc.com>
7
  * 
8
x265_2.3.tar.gz/source/common/bitstream.cpp -> x265_2.4.tar.gz/source/common/bitstream.cpp Changed
14
 
1
@@ -64,9 +64,9 @@
2
 
3
         switch (writeBytes)
4
         {
5
-        case 4: push_back(write_bits >> 24);
6
-        case 3: push_back(write_bits >> 16);
7
-        case 2: push_back(write_bits >> 8);
8
+        case 4: push_back(write_bits >> 24);  // fall-through
9
+        case 3: push_back(write_bits >> 16);  // fall-through
10
+        case 2: push_back(write_bits >> 8);   // fall-through
11
         case 1: push_back(write_bits);
12
         }
13
 
14
x265_2.3.tar.gz/source/common/bitstream.h -> x265_2.4.tar.gz/source/common/bitstream.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Author: Steve Borho <steve@borho.org>
7
  *         Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/common.cpp -> x265_2.4.tar.gz/source/common/common.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/common.h -> x265_2.4.tar.gz/source/common/common.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/constants.cpp -> x265_2.4.tar.gz/source/common/constants.cpp Changed
125
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2015 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
@@ -49,23 +49,23 @@
9
     7298.2423, 8192.0000, 9195.2091, 10321.2732, 11585.2375
10
 };
11
 
12
-// lambda2 = pow(lambda, 2) * scale (0.85);
13
+// lambda2 = 0.038 * EXP(0.234 * QP) * 256;
14
 double x265_lambda2_tab[QP_MAX_MAX + 1] =
15
 {
16
-    13.6000,       17.1349,       21.5887,       27.2000,       34.2699,
17
-    43.1773,       54.4000,       68.5397,       86.3546,       108.8000,
18
-    137.0794,      172.7092,      217.6000,      274.1588,      345.4185,
19
-    435.2000,      548.3176,      690.8369,      870.4000,      1096.6353,
20
-    1381.6739,     1740.8000,     2193.2706,     2763.3478,     3481.6000,
21
-    4386.5411,     5526.6955,     6963.2000,     8773.0822,     11053.3910,
22
-    13926.4000,    17546.1645,    22106.7819,    27852.8000,    35092.3291,
23
-    44213.5641,    55705.6000,    70184.6579,    88427.1282,    111411.2000,
24
-    140369.3159,   176854.2563,   222822.4000,   280738.6324,   353708.5127,
25
-    445644.8001,   561477.2648,   707417.0237,   891289.6000,   1122954.5277,
26
-    1414834.0484,  1782579.2003,  2245909.0566,  2829668.0981,  3565158.4000,
27
-    4491818.1146,  5659336.1938,  7130316.8013,  8983636.2264,  11318672.3923,
28
-    14260633.6000, 17967272.4585, 22637344.7751, 28521267.1953, 35934544.9165,
29
-    45274689.5567, 57042534.4000, 71869089.8338, 90549379.1181, 114085068.8008
30
+    9.7280,        12.2880,       15.5136,       19.6096,       24.7808, 
31
+    31.3344,       39.6032,       50.0480,       63.2320,       79.8976, 
32
+    100.9664,      127.5904,      161.2544,      203.7504,      257.4848, 
33
+    325.3760,      411.1616,      519.5520,      656.5376,      829.6448, 
34
+    1048.3712,     1324.7744,     1674.0608,     2115.4048,     2673.1264, 
35
+    3377.8944,     4268.4416,     5393.7920,     6815.8464,     8612.8128, 
36
+    10883.5328,    13752.9344,    17378.8160,    21960.6528,    27750.4768, 
37
+    35066.7264,    44311.8848,    55994.4704,    70757.0944,    89411.8144, 
38
+    112984.7552,   142772.5824,   180413.7728,   227978.8800,   288084.2496, 
39
+    364036.0960,   460012.2112,   581291.8784,   734546.3040,   928205.3888, 
40
+    1172921.6256,  1482155.9552,  1872918.2208,  2366702.7968,  2990670.9504, 
41
+    3779144.8832,  4775495.6288,  6034528.7424,  7625499.0080,  9635919.8464, 
42
+    12176377.0368, 15386611.7888, 19443207.2448, 24569301.7344, 31046862.8224, 
43
+    39232197.1968, 49575549.9264, 62645870.6176, 79162109.3632, 100032763.4688
44
 };
45
 
46
 #elif X265_DEPTH == 10
47
@@ -89,23 +89,23 @@
48
     1824.5606, 2048.0000, 2298.8023, 2580.3183, 2896.3094,
49
 };
50
 
51
-// lambda2 = pow(lambda, 2) * scale (0.85);
52
+// lambda2 = 0.038 * exp(0.234 * QP) * 16;
53
 double x265_lambda2_tab[QP_MAX_MAX + 1] =
54
 {
55
-    0.8500, 1.0709, 1.3493, 1.7000, 2.1419, 
56
-    2.6986, 3.4000, 4.2837, 5.3972, 6.8000, 
57
-    8.5675, 10.7943, 13.6000, 17.1349, 21.5887, 
58
-    27.2000, 34.2699, 43.1773, 54.4000, 68.5397, 
59
-    86.3546, 108.8000, 137.0794, 172.7092, 217.6000, 
60
-    274.1588, 345.4185, 435.2000, 548.3176, 690.8369, 
61
-    870.4000, 1096.6353, 1381.6739, 1740.8000, 2193.2706, 
62
-    2763.3478, 3481.6000, 4386.5411, 5526.6955, 6963.2000, 
63
-    8773.0823, 11053.3910, 13926.4000, 17546.1645, 22106.7820, 
64
-    27852.8000, 35092.3290, 44213.5640, 55705.6000, 70184.6580, 
65
-    88427.1280, 111411.2000, 140369.3161, 176854.2561, 222822.4000, 
66
-    280738.6321, 353708.5122, 445644.8000, 561477.2643, 707417.0243, 
67
-    891289.6000, 1122954.5286, 1414834.0486, 1782579.2000, 2245909.0572, 
68
-    2829668.0973, 3565158.4000, 4491818.1144, 5659336.1946, 7130316.8000, 
69
+    0.6080, 0.7680, 0.9696, 1.2256, 1.5488, 
70
+    1.9584, 2.4752, 3.1280, 3.9520, 4.9936, 
71
+    6.3104, 7.9744, 10.0784, 12.7344, 16.0928, 
72
+    20.3360, 25.6976, 32.4720, 41.0336, 51.8528, 
73
+    65.5232, 82.7984, 104.6288, 132.2128, 167.0704, 
74
+    211.1184, 266.7776, 337.1120, 425.9904, 538.3008, 
75
+    680.2208, 859.5584, 1086.1760, 1372.5408, 1734.4048, 
76
+    2191.6704, 2769.4928, 3499.6544, 4422.3184, 5588.2384, 
77
+    7061.5472, 8923.2864, 11275.8608, 14248.6800, 18005.2656, 
78
+    22752.2560, 28750.7632, 36330.7424, 45909.1440, 58012.8368, 
79
+    73307.6016, 92634.7472, 117057.3888, 147918.9248, 186916.9344, 
80
+    236196.5552, 298468.4768, 377158.0464, 476593.6880, 602244.9904, 
81
+    761023.5648, 961663.2368, 1215200.4528, 1535581.3584, 1940428.9264, 
82
+    2452012.3248, 3098471.8704, 3915366.9136, 4947631.8352, 6252047.7168
83
 };
84
 
85
 #else /* !HIGH_BIT_DEPTH */
86
@@ -129,23 +129,23 @@
87
     456.1401, 512.0000, 574.7006, 645.0796, 724.0773
88
 };
89
 
90
-// lambda2 = pow(lambda, 2) * scale (0.85);
91
+// lambda2 = 0.038 * exp(0.234 * QP)
92
 double x265_lambda2_tab[QP_MAX_MAX + 1] =
93
 {
94
-    0.0531, 0.0669, 0.0843, 0.1063, 0.1339,
95
-    0.1687, 0.2125, 0.2677, 0.3373, 0.4250,
96
-    0.5355, 0.6746, 0.8500, 1.0709, 1.3493,
97
-    1.7000, 2.1419, 2.6986, 3.4000, 4.2837,
98
-    5.3970, 6.8000, 8.5675, 10.7943, 13.6000,
99
-    17.1345, 21.5887, 27.2004, 34.2699, 43.1773,
100
-    54.4000, 68.5397, 86.3551, 108.7998, 137.0792,
101
-    172.7097, 217.6000, 274.1590, 345.4172, 435.1993,
102
-    548.3169, 690.8389, 870.4000, 1096.6362, 1381.6757,
103
-    1740.7974, 2193.2676, 2763.3460, 3481.6000, 4386.5446,
104
-    5526.6890, 6963.2049, 8773.0879, 11053.3840, 13926.4000,
105
-    17546.1542, 22106.7835, 27852.7889, 35092.3170, 44213.5749,
106
-    55705.6000, 70184.6657, 88427.1342, 111411.2172, 140369.3373,
107
-    176854.2222, 222822.4000, 280738.6627, 353708.5368, 445644.7459
108
+    0.0380, 0.0480, 0.0606, 0.0766, 0.0968,
109
+    0.1224, 0.1547, 0.1955, 0.2470, 0.3121,
110
+    0.3944, 0.4984, 0.6299, 0.7959, 1.0058,
111
+    1.2710, 1.6061, 2.0295, 2.5646, 3.2408,
112
+    4.0952, 5.1749, 6.5393, 8.2633, 10.4419,
113
+    13.1949, 16.6736, 21.0695, 26.6244, 33.6438,
114
+    42.5138, 53.7224, 67.8860, 85.7838, 108.4003,
115
+    136.9794, 173.0933, 218.7284, 276.3949, 349.2649,
116
+    441.3467, 557.7054, 704.7413, 890.5425, 1125.3291,
117
+    1422.0160, 1796.9227, 2270.6714, 2869.3215, 3625.8023,
118
+    4581.7251, 5789.6717, 7316.0868, 9244.9328, 11682.3084,
119
+    14762.2847, 18654.2798, 23572.3779, 29787.1055, 37640.3119,
120
+    47563.9728, 60103.9523, 75950.0283, 95973.8349, 121276.8079,
121
+    153250.7703, 193654.4919, 244710.4321, 309226.9897, 390752.9823
122
 };
123
 
124
 #endif
125
x265_2.3.tar.gz/source/common/constants.h -> x265_2.4.tar.gz/source/common/constants.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/contexts.h -> x265_2.4.tar.gz/source/common/contexts.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2015 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/cpu.cpp -> x265_2.4.tar.gz/source/common/cpu.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Loren Merritt <lorenm@u.washington.edu>
7
  *          Laurent Aimar <fenrir@via.ecp.fr>
8
x265_2.3.tar.gz/source/common/cpu.h -> x265_2.4.tar.gz/source/common/cpu.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Loren Merritt <lorenm@u.washington.edu>
7
  *          Steve Borho <steve@borho.org>
8
x265_2.3.tar.gz/source/common/cudata.cpp -> x265_2.4.tar.gz/source/common/cudata.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/cudata.h -> x265_2.4.tar.gz/source/common/cudata.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/dct.cpp -> x265_2.4.tar.gz/source/common/dct.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Mandar Gurav <mandar@multicorewareinc.com>
7
  *          Deepthi Devaki Akkoorath <deepthidevaki@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/deblock.cpp -> x265_2.4.tar.gz/source/common/deblock.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Author: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
 *         Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/deblock.h -> x265_2.4.tar.gz/source/common/deblock.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Author: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
 *         Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/frame.cpp -> x265_2.4.tar.gz/source/common/frame.cpp Changed
16
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Author: Steve Borho <steve@borho.org>
7
 *         Min Chen <chenm003@163.com>
8
@@ -47,6 +47,7 @@
9
     memset(&m_lowres, 0, sizeof(m_lowres));
10
     m_rcData = NULL;
11
     m_encodeStartTime = 0;
12
+    m_reconfigureRc = false;
13
 }
14
 
15
 bool Frame::create(x265_param *param, float* quantOffsets)
16
x265_2.3.tar.gz/source/common/frame.h -> x265_2.4.tar.gz/source/common/frame.h Changed
29
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Author: Steve Borho <steve@borho.org>
7
 *         Min Chen <chenm003@163.com>
8
@@ -60,6 +60,12 @@
9
     int      encodeOrder;
10
     int      sliceType;
11
     int      keptAsRef;
12
+    double   wantedBitsWindow;
13
+    double   cplxrSum;
14
+    double   shortTermCplxSum;
15
+    double   shortTermCplxCount;
16
+    int64_t  totalBits;
17
+    int64_t  encodedBits;
18
 };
19
 
20
 class Frame
21
@@ -84,6 +90,7 @@
22
     Lowres                 m_lowres;
23
     bool                   m_lowresInit;         // lowres init complete (pre-analysis)
24
     bool                   m_bChromaExtended;    // orig chroma planes motion extended for weight analysis
25
+    bool                   m_reconfigureRc;
26
 
27
     float*                 m_quantOffsets;       // points to quantOffsets in x265_picture
28
     x265_sei               m_userSEI;
29
x265_2.3.tar.gz/source/common/framedata.cpp -> x265_2.4.tar.gz/source/common/framedata.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Author: Steve Borho <steve@borho.org>
7
 *
8
x265_2.3.tar.gz/source/common/framedata.h -> x265_2.4.tar.gz/source/common/framedata.h Changed
25
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Author: Steve Borho <steve@borho.org>
7
 *
8
@@ -176,12 +176,15 @@
9
 /* Stores inter analysis data for a single frame */
10
 struct analysis_inter_data
11
 {
12
-    WeightParam* wt;
13
     int32_t*    ref;
14
     uint8_t*    depth;
15
     uint8_t*    modes;
16
     uint8_t*    partSize;
17
     uint8_t*    mergeFlag;
18
+    uint8_t*    interDir;
19
+    uint8_t*    mvpIdx[2];
20
+    int8_t*     refIdx[2];
21
+    MV*         mv[2];
22
 };
23
 
24
 struct analysis2PassFrameData
25
x265_2.3.tar.gz/source/common/intrapred.cpp -> x265_2.4.tar.gz/source/common/intrapred.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Min Chen <chenm003@163.com>
7
  *
8
x265_2.3.tar.gz/source/common/ipfilter.cpp -> x265_2.4.tar.gz/source/common/ipfilter.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Devaki <deepthidevaki@multicorewareinc.com>,
7
  *          Rajesh Paulraj <rajesh@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/loopfilter.cpp -> x265_2.4.tar.gz/source/common/loopfilter.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Praveen Kumar Tiwari <praveen@multicorewareinc.com>
7
 *          Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/lowres.cpp -> x265_2.4.tar.gz/source/common/lowres.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/lowres.h -> x265_2.4.tar.gz/source/common/lowres.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/md5.cpp -> x265_2.4.tar.gz/source/common/md5.cpp Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /*****************************************************************************
3
  * md5.cpp: Calculate MD5 for SEI
4
  *****************************************************************************
5
- * Copyright (C) 2011-2012 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Min Chen <chenm003@163.com>
9
  *
10
x265_2.3.tar.gz/source/common/md5.h -> x265_2.4.tar.gz/source/common/md5.h Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /*****************************************************************************
3
  * md5.h: Calculate MD5
4
  *****************************************************************************
5
- * Copyright (C) 2011-2012 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Min Chen <chenm003@163.com>
9
  *
10
x265_2.3.tar.gz/source/common/mv.h -> x265_2.4.tar.gz/source/common/mv.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/param.cpp -> x265_2.4.tar.gz/source/common/param.cpp Changed
123
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
  *          Min Chen <min.chen@multicorewareinc.com>
8
@@ -187,7 +187,7 @@
9
     /* SAO Loop Filter */
10
     param->bEnableSAO = 1;
11
     param->bSaoNonDeblocked = 0;
12
-
13
+    param->bLimitSAO = 0;
14
     /* Coding Quality */
15
     param->cbQpOffset = 0;
16
     param->crQpOffset = 0;
17
@@ -270,7 +270,11 @@
18
     param->bOptRefListLengthPPS = 1;
19
     param->bOptCUDeltaQP        = 0;
20
     param->bAQMotion = 0;
21
+    param->bHDROpt = 0;
22
+    param->analysisRefineLevel = 5;
23
 
24
+    param->toneMapFile = NULL;
25
+    param->bDhdr10opt = 0;
26
 }
27
 
28
 int x265_param_default_preset(x265_param* param, const char* preset, const char* tune)
29
@@ -394,6 +398,7 @@
30
             param->limitModes = 1;
31
             param->bIntraInBFrames = 1;
32
             param->lookaheadSlices = 4; // limit parallelism as already enough work exists
33
+            param->limitTU = 4;
34
         }
35
         else if (!strcmp(preset, "veryslow"))
36
         {
37
@@ -415,6 +420,7 @@
38
             param->limitModes = 1;
39
             param->bIntraInBFrames = 1;
40
             param->lookaheadSlices = 0; // disabled for best quality
41
+            param->limitTU = 4;
42
         }
43
         else if (!strcmp(preset, "placebo"))
44
         {
45
@@ -932,6 +938,7 @@
46
         OPT("multi-pass-opt-distortion") p->analysisMultiPassDistortion = atobool(value);
47
         OPT("aq-motion") p->bAQMotion = atobool(value);
48
         OPT("dynamic-rd") p->dynamicRd = atof(value);
49
+        OPT("refine-level") p->analysisRefineLevel = atoi(value);
50
         OPT("ssim-rd")
51
         {
52
             int bval = atobool(value);
53
@@ -943,6 +950,10 @@
54
             }
55
         }
56
         OPT("hdr") p->bEmitHDRSEI = atobool(value);
57
+        OPT("hdr-opt") p->bHDROpt = atobool(value);
58
+        OPT("limit-sao") p->bLimitSAO = atobool(value);
59
+        OPT("dhdr10-info") p->toneMapFile = strdup(value);
60
+        OPT("dhdr10-opt") p->bDhdr10opt = atobool(value);
61
         else
62
             return X265_PARAM_BAD_NAME;
63
     }
64
@@ -1275,6 +1286,8 @@
65
           "Strict-cbr cannot be applied without specifying target bitrate or vbv bufsize");
66
     CHECK(param->analysisMode && (param->analysisMode < X265_ANALYSIS_OFF || param->analysisMode > X265_ANALYSIS_LOAD),
67
         "Invalid analysis mode. Analysis mode 0: OFF 1: SAVE : 2 LOAD");
68
+    CHECK(param->analysisMode && (param->analysisRefineLevel < 1 || param->analysisRefineLevel > 10),
69
+        "Invalid analysis refine level. Value must be between 1 and 10 (inclusive)");
70
     CHECK(param->rc.qpMax < QP_MIN || param->rc.qpMax > QP_MAX_MAX,
71
         "qpmax exceeds supported range (0 to 69)");
72
     CHECK(param->rc.qpMin < QP_MIN || param->rc.qpMin > QP_MAX_MAX,
73
@@ -1423,6 +1436,7 @@
74
     TOOLOPT(param->limitModes, "limit-modes");
75
     TOOLVAL(param->rdLevel, "rd=%d");
76
     TOOLVAL(param->dynamicRd, "dynamic-rd=%.2f");
77
+    TOOLOPT(param->bSsimRd, "ssim-rd");
78
     TOOLVAL(param->psyRd, "psy-rd=%.2lf");
79
     TOOLVAL(param->rdoqLevel, "rdoq=%d");
80
     TOOLVAL(param->psyRdoq, "psy-rdoq=%.2lf");
81
@@ -1459,6 +1473,9 @@
82
     TOOLOPT(!param->bSaoNonDeblocked && param->bEnableSAO, "sao");
83
     TOOLOPT(param->rc.bStatWrite, "stats-write");
84
     TOOLOPT(param->rc.bStatRead,  "stats-read");
85
+#if ENABLE_DYNAMIC_HDR10
86
+    TOOLVAL(param->toneMapFile != NULL, "dhdr10-info");
87
+#endif
88
     x265_log(param, X265_LOG_INFO, "tools:%s\n", buf);
89
     fflush(stderr);
90
 }
91
@@ -1523,6 +1540,7 @@
92
     s += sprintf(s, " limit-tu=%d", p->limitTU);
93
     s += sprintf(s, " rdoq-level=%d", p->rdoqLevel);
94
     s += sprintf(s, " dynamic-rd=%.2f", p->dynamicRd);
95
+    BOOL(p->bSsimRd, "ssim-rd");
96
     BOOL(p->bEnableSignHiding, "signhide");
97
     BOOL(p->bEnableTransformSkip, "tskip");
98
     s += sprintf(s, " nr-intra=%d", p->noiseReductionIntra);
99
@@ -1648,6 +1666,10 @@
100
     BOOL(p->bOptCUDeltaQP, "opt-cu-delta-qp");
101
     BOOL(p->bAQMotion, "aq-motion");
102
     BOOL(p->bEmitHDRSEI, "hdr");
103
+    BOOL(p->bHDROpt, "hdr-opt");
104
+    BOOL(p->bDhdr10opt, "dhdr10-opt");
105
+    s += sprintf(s, " refine-level=%d", p->analysisRefineLevel);
106
+    BOOL(p->bLimitSAO, "limit-sao");
107
 #undef BOOL
108
     return buf;
109
 }
110
@@ -1657,10 +1679,10 @@
111
     if (!param->rc.lambdaFileName)
112
         return false;
113
 
114
-    FILE *lfn = fopen(param->rc.lambdaFileName, "r");
115
+    FILE *lfn = x265_fopen(param->rc.lambdaFileName, "r");
116
     if (!lfn)
117
     {
118
-        x265_log(param, X265_LOG_ERROR, "unable to read lambda file <%s>\n", param->rc.lambdaFileName);
119
+        x265_log_file(param, X265_LOG_ERROR, "unable to read lambda file <%s>\n", param->rc.lambdaFileName);
120
         return true;
121
     }
122
 
123
x265_2.3.tar.gz/source/common/param.h -> x265_2.4.tar.gz/source/common/param.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/piclist.cpp -> x265_2.4.tar.gz/source/common/piclist.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/piclist.h -> x265_2.4.tar.gz/source/common/piclist.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/picyuv.cpp -> x265_2.4.tar.gz/source/common/picyuv.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/picyuv.h -> x265_2.4.tar.gz/source/common/picyuv.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/pixel.cpp -> x265_2.4.tar.gz/source/common/pixel.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/ppc/dct_altivec.cpp -> x265_2.4.tar.gz/source/common/ppc/dct_altivec.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Roger Moussalli <rmoussal@us.ibm.com>
7
  *          Min Chen <min.chen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/ppc/intrapred_altivec.cpp -> x265_2.4.tar.gz/source/common/ppc/intrapred_altivec.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Roger Moussalli <rmoussal@us.ibm.com>
7
  *          Min Chen <min.chen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/ppc/ipfilter_altivec.cpp -> x265_2.4.tar.gz/source/common/ppc/ipfilter_altivec.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Roger Moussalli <rmoussal@us.ibm.com>
7
  *          Min Chen <min.chen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/ppc/pixel_altivec.cpp -> x265_2.4.tar.gz/source/common/ppc/pixel_altivec.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/ppc/ppccommon.h -> x265_2.4.tar.gz/source/common/ppc/ppccommon.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Min Chen <min.chen@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/predict.cpp -> x265_2.4.tar.gz/source/common/predict.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
 *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/predict.h -> x265_2.4.tar.gz/source/common/predict.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
 *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/primitives.cpp -> x265_2.4.tar.gz/source/common/primitives.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/primitives.h -> x265_2.4.tar.gz/source/common/primitives.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/quant.cpp -> x265_2.4.tar.gz/source/common/quant.cpp Changed
19
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -225,8 +225,8 @@
9
     m_rdoqLevel = ctu.m_encData->m_param->rdoqLevel;
10
     if (ctu.m_chromaFormat != X265_CSP_I400)
11
     {
12
-        setChromaQP(qp + ctu.m_slice->m_pps->chromaQpOffset[0], TEXT_CHROMA_U, ctu.m_chromaFormat);
13
-        setChromaQP(qp + ctu.m_slice->m_pps->chromaQpOffset[1], TEXT_CHROMA_V, ctu.m_chromaFormat);
14
+        setChromaQP(qp + ctu.m_slice->m_pps->chromaQpOffset[0] + ctu.m_slice->m_chromaQpOffset[0], TEXT_CHROMA_U, ctu.m_chromaFormat);
15
+        setChromaQP(qp + ctu.m_slice->m_pps->chromaQpOffset[1] + ctu.m_slice->m_chromaQpOffset[1], TEXT_CHROMA_V, ctu.m_chromaFormat);
16
     }
17
 }
18
 
19
x265_2.3.tar.gz/source/common/quant.h -> x265_2.4.tar.gz/source/common/quant.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/scalinglist.cpp -> x265_2.4.tar.gz/source/common/scalinglist.cpp Changed
57
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
@@ -245,10 +245,10 @@
9
 
10
 bool ScalingList::parseScalingList(const char* filename)
11
 {
12
-    FILE *fp = fopen(filename, "r");
13
+    FILE *fp = x265_fopen(filename, "r");
14
     if (!fp)
15
     {
16
-        x265_log(NULL, X265_LOG_ERROR, "can't open scaling list file %s\n", filename);
17
+        x265_log_file(NULL, X265_LOG_ERROR, "can't open scaling list file %s\n", filename);
18
         return true;
19
     }
20
 
21
@@ -268,7 +268,7 @@
22
                 char *ret = fgets(line, 1024, fp);
23
                 if (!ret || (!strstr(line, MatrixType[sizeIdc][listIdc]) && feof(fp)))
24
                 {
25
-                    x265_log(NULL, X265_LOG_ERROR, "can't read matrix from %s\n", filename);
26
+                    x265_log_file(NULL, X265_LOG_ERROR, "can't read matrix from %s\n", filename);
27
                     return true;
28
                 }
29
             }
30
@@ -279,7 +279,7 @@
31
                 int data;
32
                 if (fscanf(fp, "%d,", &data) != 1)
33
                 {
34
-                    x265_log(NULL, X265_LOG_ERROR, "can't read matrix from %s\n", filename);
35
+                    x265_log_file(NULL, X265_LOG_ERROR, "can't read matrix from %s\n", filename);
36
                     return true;
37
                 }
38
                 src[i] = data;
39
@@ -295,7 +295,7 @@
40
                     char *ret = fgets(line, 1024, fp);
41
                     if (!ret || (!strstr(line, MatrixType_DC[sizeIdc][listIdc]) && feof(fp)))
42
                     {
43
-                        x265_log(NULL, X265_LOG_ERROR, "can't read DC from %s\n", filename);
44
+                        x265_log_file(NULL, X265_LOG_ERROR, "can't read DC from %s\n", filename);
45
                         return true;
46
                     }
47
                 }
48
@@ -304,7 +304,7 @@
49
                 int data;
50
                 if (fscanf(fp, "%d,", &data) != 1)
51
                 {
52
-                    x265_log(NULL, X265_LOG_ERROR, "can't read matrix from %s\n", filename);
53
+                    x265_log_file(NULL, X265_LOG_ERROR, "can't read matrix from %s\n", filename);
54
                     return true;
55
                 }
56
 
57
x265_2.3.tar.gz/source/common/scalinglist.h -> x265_2.4.tar.gz/source/common/scalinglist.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/shortyuv.cpp -> x265_2.4.tar.gz/source/common/shortyuv.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
  *
8
x265_2.3.tar.gz/source/common/shortyuv.h -> x265_2.4.tar.gz/source/common/shortyuv.h Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /*****************************************************************************
3
  * x265: ShortYUV class for short sized YUV-style frames
4
  *****************************************************************************
5
- * Copyright (C) 2013 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
9
  *
10
x265_2.3.tar.gz/source/common/slice.cpp -> x265_2.4.tar.gz/source/common/slice.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/slice.h -> x265_2.4.tar.gz/source/common/slice.h Changed
32
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -289,6 +289,7 @@
9
     bool     bPicDisableDeblockingFilter;
10
 
11
     int      numRefIdxDefault[2];
12
+    bool     pps_slice_chroma_qp_offsets_present_flag;
13
 };
14
 
15
 struct WeightParam
16
@@ -339,6 +340,7 @@
17
     NalUnitType m_nalUnitType;
18
     SliceType   m_sliceType;
19
     int         m_sliceQp;
20
+    int         m_chromaQpOffset[2];
21
     int         m_poc;
22
     int         m_lastIDR;
23
     int         m_rpsIdx;
24
@@ -372,6 +374,7 @@
25
         numRefIdxDefault[0] = 1;
26
         numRefIdxDefault[1] = 1;
27
         m_rpsIdx = -1;
28
+        m_chromaQpOffset[0] = m_chromaQpOffset[1] = 0;
29
     }
30
 
31
     void disableWeights();
32
x265_2.3.tar.gz/source/common/threading.cpp -> x265_2.4.tar.gz/source/common/threading.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/threading.h -> x265_2.4.tar.gz/source/common/threading.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/threadpool.cpp -> x265_2.4.tar.gz/source/common/threadpool.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/threadpool.h -> x265_2.4.tar.gz/source/common/threadpool.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/vec/dct-sse3.cpp -> x265_2.4.tar.gz/source/common/vec/dct-sse3.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/vec/dct-sse41.cpp -> x265_2.4.tar.gz/source/common/vec/dct-sse41.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/vec/dct-ssse3.cpp -> x265_2.4.tar.gz/source/common/vec/dct-ssse3.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/vec/vec-primitives.cpp -> x265_2.4.tar.gz/source/common/vec/vec-primitives.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/version.cpp -> x265_2.4.tar.gz/source/common/version.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/wavefront.cpp -> x265_2.4.tar.gz/source/common/wavefront.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/wavefront.h -> x265_2.4.tar.gz/source/common/wavefront.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/winxp.cpp -> x265_2.4.tar.gz/source/common/winxp.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/winxp.h -> x265_2.4.tar.gz/source/common/winxp.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/x86/asm-primitives.cpp -> x265_2.4.tar.gz/source/common/x86/asm-primitives.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/blockcopy8.asm -> x265_2.4.tar.gz/source/common/x86/blockcopy8.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Praveen Kumar Tiwari <praveen@multicorewareinc.com>
7
 ;*          Murugan Vairavel <murugan@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/blockcopy8.h -> x265_2.4.tar.gz/source/common/x86/blockcopy8.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
 ;*          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/x86/const-a.asm -> x265_2.4.tar.gz/source/common/x86/const-a.asm Changed
12
 
1
@@ -1,8 +1,8 @@
2
 ;*****************************************************************************
3
 ;* const-a.asm: x86 global constants
4
 ;*****************************************************************************
5
-;* Copyright (C) 2010-2013 x264 project
6
-;* Copyright (C) 2013-2015 x265 project
7
+;* Copyright (C) 2003-2013 x264 project
8
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
9
 ;*
10
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
11
 ;*          Fiona Glaser <fiona@x264.com>
12
x265_2.3.tar.gz/source/common/x86/cpu-a.asm -> x265_2.4.tar.gz/source/common/x86/cpu-a.asm Changed
10
 
1
@@ -2,7 +2,7 @@
2
 ;* cpu-a.asm: x86 cpu utilities
3
 ;*****************************************************************************
4
 ;* Copyright (C) 2003-2013 x264 project
5
-;* Copyright (C) 2013-2015 x265 project
6
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
7
 ;*
8
 ;* Authors: Laurent Aimar <fenrir@via.ecp.fr>
9
 ;*          Loren Merritt <lorenm@u.washington.edu>
10
x265_2.3.tar.gz/source/common/x86/dct8.asm -> x265_2.4.tar.gz/source/common/x86/dct8.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Nabajit Deka <nabajit@multicorewareinc.com>
7
 ;*          Min Chen <chenm003@163.com> <min.chen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/dct8.h -> x265_2.4.tar.gz/source/common/x86/dct8.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Nabajit Deka <nabajit@multicorewareinc.com>
7
 ;*          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/x86/intrapred.h -> x265_2.4.tar.gz/source/common/x86/intrapred.h Changed
9
 
1
@@ -2,6 +2,7 @@
2
  * intrapred.h: Intra Prediction metrics
3
  *****************************************************************************
4
  * Copyright (C) 2003-2013 x264 project
5
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
6
  *
7
  * Authors: Min Chen <chenm003@163.com> <min.chen@multicorewareinc.com>
8
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
9
x265_2.3.tar.gz/source/common/x86/intrapred16.asm -> x265_2.4.tar.gz/source/common/x86/intrapred16.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
7
 ;*          Yuvaraj Venkatesh <yuvaraj@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/intrapred8.asm -> x265_2.4.tar.gz/source/common/x86/intrapred8.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Min Chen <chenm003@163.com> <min.chen@multicorewareinc.com>
7
 ;*          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/intrapred8_allangs.asm -> x265_2.4.tar.gz/source/common/x86/intrapred8_allangs.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Min Chen <chenm003@163.com> <min.chen@multicorewareinc.com>
7
 ;*          Praveen Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/ipfilter16.asm -> x265_2.4.tar.gz/source/common/x86/ipfilter16.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Nabajit Deka <nabajit@multicorewareinc.com>
7
 ;*          Murugan Vairavel <murugan@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/ipfilter8.asm -> x265_2.4.tar.gz/source/common/x86/ipfilter8.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Min Chen <chenm003@163.com>
7
 ;*          Nabajit Deka <nabajit@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/ipfilter8.h -> x265_2.4.tar.gz/source/common/x86/ipfilter8.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/x86/loopfilter.asm -> x265_2.4.tar.gz/source/common/x86/loopfilter.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Min Chen <chenm001@163.com>
7
 ;*          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/loopfilter.h -> x265_2.4.tar.gz/source/common/x86/loopfilter.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
7
  *          Praveen Kumar Tiwari <praveen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/mc-a.asm -> x265_2.4.tar.gz/source/common/x86/mc-a.asm Changed
10
 
1
@@ -2,7 +2,7 @@
2
 ;* mc-a.asm: x86 motion compensation
3
 ;*****************************************************************************
4
 ;* Copyright (C) 2003-2013 x264 project
5
-;* Copyright (C) 2013-2015 x265 project
6
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
7
 ;*
8
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
9
 ;*          Fiona Glaser <fiona@x264.com>
10
x265_2.3.tar.gz/source/common/x86/mc-a2.asm -> x265_2.4.tar.gz/source/common/x86/mc-a2.asm Changed
12
 
1
@@ -1,8 +1,8 @@
2
 ;*****************************************************************************
3
 ;* mc-a2.asm: x86 motion compensation
4
 ;*****************************************************************************
5
-;* Copyright (C) 2005-2013 x264 project
6
-;* Copyright (C) 2013-2015 x265 project
7
+;* Copyright (C) 2003-2013 x264 project
8
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
9
 ;*
10
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
11
 ;*          Fiona Glaser <fiona@x264.com>
12
x265_2.3.tar.gz/source/common/x86/mc.h -> x265_2.4.tar.gz/source/common/x86/mc.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/common/x86/pixel-32.asm -> x265_2.4.tar.gz/source/common/x86/pixel-32.asm Changed
9
 
1
@@ -2,6 +2,7 @@
2
 ;* pixel-32.asm: x86_32 pixel metrics
3
 ;*****************************************************************************
4
 ;* Copyright (C) 2003-2013 x264 project
5
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
6
 ;*
7
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
8
 ;*          Laurent Aimar <fenrir@via.ecp.fr>
9
x265_2.3.tar.gz/source/common/x86/pixel-a.asm -> x265_2.4.tar.gz/source/common/x86/pixel-a.asm Changed
10
 
1
@@ -2,7 +2,7 @@
2
 ;* pixel.asm: x86 pixel metrics
3
 ;*****************************************************************************
4
 ;* Copyright (C) 2003-2013 x264 project
5
-;* Copyright (C) 2013-2015 x265 project
6
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
7
 ;*
8
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
9
 ;*          Holger Lubitz <holger@lubitz.org>
10
x265_2.3.tar.gz/source/common/x86/pixel-util.h -> x265_2.4.tar.gz/source/common/x86/pixel-util.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
 ;*          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/x86/pixel-util8.asm -> x265_2.4.tar.gz/source/common/x86/pixel-util8.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Min Chen <chenm003@163.com> <min.chen@multicorewareinc.com>
7
 ;*          Nabajit Deka <nabajit@multicorewareinc.com>
8
x265_2.3.tar.gz/source/common/x86/pixel.h -> x265_2.4.tar.gz/source/common/x86/pixel.h Changed
10
 
1
@@ -2,7 +2,7 @@
2
  * pixel.h: x86 pixel metrics
3
  *****************************************************************************
4
  * Copyright (C) 2003-2013 x264 project
5
- * Copyright (C) 2013-2015 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
9
  *          Loren Merritt <lorenm@u.washington.edu>
10
x265_2.3.tar.gz/source/common/x86/pixeladd8.asm -> x265_2.4.tar.gz/source/common/x86/pixeladd8.asm Changed
8
 
1
@@ -1,5 +1,5 @@
2
 ;*****************************************************************************
3
-;* Copyright (C) 2013 x265 project
4
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 ;*
6
 ;* Authors: Praveen Kumar Tiwari <praveen@multicorewareinc.com>
7
 ;*          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/x86/sad-a.asm -> x265_2.4.tar.gz/source/common/x86/sad-a.asm Changed
10
 
1
@@ -2,7 +2,7 @@
2
 ;* sad-a.asm: x86 sad functions
3
 ;*****************************************************************************
4
 ;* Copyright (C) 2003-2013 x264 project
5
-;* Copyright (C) 2013-2015 x265 project
6
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
7
 ;*
8
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
9
 ;*          Fiona Glaser <fiona@x264.com>
10
x265_2.3.tar.gz/source/common/x86/sad16-a.asm -> x265_2.4.tar.gz/source/common/x86/sad16-a.asm Changed
11
 
1
@@ -1,7 +1,8 @@
2
 ;*****************************************************************************
3
 ;* sad16-a.asm: x86 high depth sad functions
4
 ;*****************************************************************************
5
-;* Copyright (C) 2010-2013 x264 project
6
+;* Copyright (C) 2003-2013 x264 project
7
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
8
 ;*
9
 ;* Authors: Oskar Arvidsson <oskar@irock.se>
10
 ;*          Henrik Gramner <henrik@gramner.com>
11
x265_2.3.tar.gz/source/common/x86/ssd-a.asm -> x265_2.4.tar.gz/source/common/x86/ssd-a.asm Changed
10
 
1
@@ -2,7 +2,7 @@
2
 ;* ssd-a.asm: x86 ssd functions
3
 ;*****************************************************************************
4
 ;* Copyright (C) 2003-2013 x264 project
5
-;* Copyright (C) 2013-2015 x265 project
6
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
7
 ;*
8
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
9
 ;*          Fiona Glaser <fiona@x264.com>
10
x265_2.3.tar.gz/source/common/x86/x86inc.asm -> x265_2.4.tar.gz/source/common/x86/x86inc.asm Changed
12
 
1
@@ -1,8 +1,8 @@
2
 ;*****************************************************************************
3
 ;* x86inc.asm: x264asm abstraction layer
4
 ;*****************************************************************************
5
-;* Copyright (C) 2005-2014 x264 project
6
-;*               2013-2014 x265 project
7
+;* Copyright (C) 2003-2013 x264 project
8
+;* Copyright (C) 2013-2017 MulticoreWarae, Inc
9
 ;*
10
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
11
 ;*          Anton Mitrofanov <BugMaster@narod.ru>
12
x265_2.3.tar.gz/source/common/x86/x86util.asm -> x265_2.4.tar.gz/source/common/x86/x86util.asm Changed
11
 
1
@@ -1,7 +1,8 @@
2
 ;*****************************************************************************
3
 ;* x86util.asm: x86 utility macros
4
 ;*****************************************************************************
5
-;* Copyright (C) 2008-2013 x264 project
6
+;* Copyright (C) 2003-2013 x264 project
7
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
8
 ;*
9
 ;* Authors: Holger Lubitz <holger@lubitz.org>
10
 ;*          Loren Merritt <lorenm@u.washington.edu>
11
x265_2.3.tar.gz/source/common/yuv.cpp -> x265_2.4.tar.gz/source/common/yuv.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/common/yuv.h -> x265_2.4.tar.gz/source/common/yuv.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.4.tar.gz/source/dynamicHDR10/BasicStructures.cpp Added
42
 
1
@@ -0,0 +1,40 @@
2
+/**
3
+ * @file                       BasicStructures.cpp
4
+ * @brief                      Defines the structure of metadata parameters
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#include "BasicStructures.h"
28
+#include "vector"
29
+
30
+struct PercentileLuminance{
31
+
32
+    float averageLuminance = 0.0;
33
+    float maxRLuminance = 0.0;
34
+    float maxGLuminance = 0.0;
35
+    float maxBLuminance = 0.0;
36
+    int order;
37
+    std::vector<unsigned int> percentiles;
38
+};
39
+
40
+
41
+
42
x265_2.4.tar.gz/source/dynamicHDR10/BasicStructures.h Added
52
 
1
@@ -0,0 +1,50 @@
2
+/**
3
+ * @file                       BasicStructures.h
4
+ * @brief                      Defines the structure of metadata parameters
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#ifndef BASICSTRUCTURES_H
28
+#define BASICSTRUCTURES_H
29
+
30
+#include <vector>
31
+
32
+
33
+struct LuminanceParameters
34
+{
35
+    float averageLuminance = 0.0;
36
+    float maxRLuminance = 0.0;
37
+    float maxGLuminance = 0.0;
38
+    float maxBLuminance = 0.0;
39
+    int order;
40
+    std::vector<unsigned int> percentiles;
41
+};
42
+
43
+struct BezierCurveData
44
+{
45
+    int order;
46
+    int sPx;
47
+    int sPy;
48
+    std::vector<int> coeff;
49
+};
50
+
51
+#endif // BASICSTRUCTURES_H
52
x265_2.4.tar.gz/source/dynamicHDR10/CMakeLists.txt Added
178
 
1
@@ -0,0 +1,175 @@
2
+# vim: syntax=cmake
3
+if(ENABLE_DYNAMIC_HDR10)
4
+
5
+add_library(dynamicHDR10 OBJECT 
6
+    BasicStructures.cpp BasicStructures.h
7
+    json11/json11.cpp json11/json11.h
8
+    JsonHelper.cpp JsonHelper.h
9
+    metadataFromJson.cpp metadataFromJson.h
10
+    SeiMetadataDictionary.cpp SeiMetadataDictionary.h
11
+    hdr10plus.h
12
+    api.cpp )
13
+
14
+else()
15
+cmake_minimum_required (VERSION 2.8.11)
16
+project(dynamicHDR10)
17
+include(CheckIncludeFiles)
18
+include(CheckFunctionExists)
19
+include(CheckSymbolExists)
20
+include(CheckCXXCompilerFlag)
21
+
22
+SET(CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/cmake" "${CMAKE_MODULE_PATH}")
23
+
24
+if(GCC)
25
+    add_definitions(-Wall -Wextra -Wshadow)
26
+    add_definitions(-D__STDC_LIMIT_MACROS=1)
27
+    add_definitions(-std=c++11)
28
+    if(ENABLE_PIC)
29
+         add_definitions(-fPIC)
30
+    endif(ENABLE_PIC)
31
+    if(NATIVE_BUILD)
32
+        if(INTEL_CXX)
33
+            add_definitions(-xhost)
34
+        else()
35
+            add_definitions(-march=native)
36
+        endif()
37
+    elseif(X86 AND NOT X64)
38
+        string(FIND "${CMAKE_CXX_FLAGS}" "-march" marchPos)
39
+        if(marchPos LESS "0")
40
+            add_definitions(-march=i686)
41
+            if(WIN32 AND NOT INTEL_CXX AND NOT CLANG AND
42
+               CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 6.0 AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 7.0)
43
+                add_definitions(-mpreferred-stack-boundary=2)
44
+            endif()
45
+        endif()
46
+    endif()
47
+    if(ARM AND CROSS_COMPILE_ARM)
48
+        set(ARM_ARGS -march=armv6 -mfloat-abi=soft -mfpu=vfp -marm -fPIC)
49
+    elseif(ARM)
50
+        find_package(Neon)
51
+        if(CPU_HAS_NEON)
52
+            set(ARM_ARGS -mcpu=native -mfloat-abi=hard -mfpu=neon -marm -fPIC)
53
+            add_definitions(-DHAVE_NEON)
54
+        else()
55
+            set(ARM_ARGS -mcpu=native -mfloat-abi=hard -mfpu=vfp -marm)
56
+        endif()
57
+    endif()
58
+    add_definitions(${ARM_ARGS})
59
+    if(FPROFILE_GENERATE)
60
+        if(INTEL_CXX)
61
+            add_definitions(-prof-gen -prof-dir="${CMAKE_CURRENT_BINARY_DIR}")
62
+            list(APPEND LINKER_OPTIONS "-prof-gen")
63
+        else()
64
+            check_cxx_compiler_flag(-fprofile-generate CC_HAS_PROFILE_GENERATE)
65
+            if(CC_HAS_PROFILE_GENERATE)
66
+                add_definitions(-fprofile-generate)
67
+                list(APPEND LINKER_OPTIONS "-fprofile-generate")
68
+            endif(CC_HAS_PROFILE_GENERATE)
69
+        endif(INTEL_CXX)
70
+    endif(FPROFILE_GENERATE)
71
+    if(FPROFILE_USE)
72
+        if(INTEL_CXX)
73
+            add_definitions(-prof-use -prof-dir="${CMAKE_CURRENT_BINARY_DIR}")
74
+            list(APPEND LINKER_OPTIONS "-prof-use")
75
+        else()
76
+            check_cxx_compiler_flag(-fprofile-use CC_HAS_PROFILE_USE)
77
+            check_cxx_compiler_flag(-fprofile-correction CC_HAS_PROFILE_CORRECTION)
78
+            check_cxx_compiler_flag(-Wno-error=coverage-mismatch CC_HAS_COVMISMATCH)
79
+            if(CC_HAS_PROFILE_USE)
80
+                add_definitions(-fprofile-use)
81
+                list(APPEND LINKER_OPTIONS "-fprofile-use")
82
+            endif(CC_HAS_PROFILE_USE)
83
+            if(CC_HAS_PROFILE_CORRECTION)
84
+                # auto-correct corrupted counters (happens a lot with x265)
85
+                add_definitions(-fprofile-correction)
86
+            endif(CC_HAS_PROFILE_CORRECTION)
87
+            if(CC_HAS_COVMISMATCH)
88
+                # ignore coverage mismatches (also happens a lot)
89
+                add_definitions(-Wno-error=coverage-mismatch)
90
+            endif(CC_HAS_COVMISMATCH)
91
+        endif(INTEL_CXX)
92
+    endif(FPROFILE_USE)
93
+    if(STATIC_LINK_CRT)
94
+        add_definitions(-static)
95
+        list(APPEND LINKER_OPTIONS "-static")
96
+    endif(STATIC_LINK_CRT)
97
+    check_cxx_compiler_flag(-Wno-strict-overflow CC_HAS_NO_STRICT_OVERFLOW)
98
+    check_cxx_compiler_flag(-Wno-narrowing CC_HAS_NO_NARROWING) 
99
+    check_cxx_compiler_flag(-Wno-array-bounds CC_HAS_NO_ARRAY_BOUNDS) 
100
+    if (CC_HAS_NO_ARRAY_BOUNDS)
101
+        add_definitions(-Wno-array-bounds) # these are unhelpful
102
+    endif()
103
+    check_cxx_compiler_flag(-ffast-math CC_HAS_FAST_MATH) 
104
+    if (CC_HAS_FAST_MATH)
105
+        add_definitions(-ffast-math)
106
+    endif()
107
+    check_cxx_compiler_flag(-mstackrealign CC_HAS_STACK_REALIGN) 
108
+    if (CC_HAS_STACK_REALIGN)
109
+        add_definitions(-mstackrealign)
110
+    endif()
111
+    # Disable exceptions. Reduce executable size, increase compability.
112
+    check_cxx_compiler_flag(-fno-exceptions CC_HAS_FNO_EXCEPTIONS_FLAG)
113
+    if(CC_HAS_FNO_EXCEPTIONS_FLAG)
114
+        add_definitions(-fno-exceptions)
115
+    endif()
116
+    set(FSANITIZE "" CACHE STRING "-fsanitize options for GCC/clang")
117
+    if(FSANITIZE)
118
+        add_definitions(-fsanitize=${FSANITIZE})
119
+        # clang and gcc need the sanitize options to be passed at link
120
+        # time so the appropriate ASAN/TSAN runtime libraries can be
121
+        # linked.
122
+        list(APPEND LINKER_OPTIONS "-fsanitize=${FSANITIZE}")
123
+    endif()
124
+    option(ENABLE_AGGRESSIVE_CHECKS "Enable stack protection and -ftrapv" OFF)
125
+    if(ENABLE_AGGRESSIVE_CHECKS)
126
+        # use with care, -ftrapv can cause testbench SIGILL exceptions
127
+        # since it is testing corner cases of signed integer math
128
+        add_definitions(-DUSING_FTRAPV=1)
129
+        check_cxx_compiler_flag(-fsanitize=undefined-trap CC_HAS_CATCH_UNDEFINED) # clang
130
+        check_cxx_compiler_flag(-ftrapv CC_HAS_FTRAPV)                            # gcc
131
+        check_cxx_compiler_flag(-fstack-protector-all CC_HAS_STACK_PROTECT)       # gcc
132
+        if(CC_HAS_FTRAPV)
133
+            add_definitions(-ftrapv)
134
+        endif()
135
+        if(CC_HAS_CATCH_UNDEFINED)
136
+            add_definitions(-fsanitize=undefined-trap -fsanitize-undefined-trap-on-error)
137
+        endif()
138
+        if(CC_HAS_STACK_PROTECT)
139
+            add_definitions(-fstack-protector-all)
140
+            if(MINGW)
141
+                list(APPEND PLATFORM_LIBS ssp)
142
+            endif()
143
+        endif()
144
+    endif(ENABLE_AGGRESSIVE_CHECKS)
145
+    execute_process(COMMAND ${CMAKE_CXX_COMPILER} -dumpversion OUTPUT_VARIABLE CC_VERSION)
146
+endif(GCC)
147
+
148
+# Build options
149
+set(LIB_INSTALL_DIR lib CACHE STRING "Install location of libraries")
150
+set(BIN_INSTALL_DIR bin CACHE STRING "Install location of executables")
151
+    
152
+option(ENABLE_SHARED "Build shared library" OFF)
153
+
154
+if(ENABLE_SHARED)
155
+    add_library(dynamicHDR10 SHARED
156
+        json11/json11.cpp json11/json11.h
157
+        BasicStructures.cpp BasicStructures.h
158
+        JsonHelper.cpp JsonHelper.h
159
+        metadataFromJson.cpp metadataFromJson.h
160
+        SeiMetadataDictionary.cpp SeiMetadataDictionary.h
161
+        hdr10plus.h api.cpp )
162
+else()
163
+    add_library(dynamicHDR10 STATIC
164
+    json11/json11.cpp json11/json11.h
165
+    BasicStructures.cpp BasicStructures.h
166
+    JsonHelper.cpp JsonHelper.h
167
+    metadataFromJson.cpp metadataFromJson.h
168
+    SeiMetadataDictionary.cpp SeiMetadataDictionary.h
169
+    hdr10plus.h api.cpp )
170
+endif()
171
+
172
+install (TARGETS dynamicHDR10
173
+    LIBRARY DESTINATION ${LIB_INSTALL_DIR}
174
+    ARCHIVE DESTINATION ${LIB_INSTALL_DIR})
175
+install(FILES hdr10plus.h DESTINATION include)
176
+endif()
177
\ No newline at end of file
178
x265_2.4.tar.gz/source/dynamicHDR10/JsonHelper.cpp Added
223
 
1
@@ -0,0 +1,221 @@
2
+/**
3
+ * @file                       JsonHelper.cpp
4
+ * @brief                      Helper class for JSON parsing
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#include "JsonHelper.h"
28
+#include "sys/stat.h"
29
+#include <fstream>
30
+#include <iostream>
31
+using namespace std;
32
+
33
+JsonObject JsonHelper::add(string key, string value, JsonObject &json)
34
+{
35
+
36
+    json[key] =  value;
37
+    return json;
38
+}
39
+
40
+bool JsonHelper::writeJson(JsonObject json, string path)
41
+{
42
+    if(!validatePathExtension(path))
43
+    {
44
+        return false;
45
+    }
46
+
47
+    ofstream JsonSaveFile(path);
48
+    string jsonString;
49
+    jsonString = dump(json);
50
+    JsonSaveFile << jsonString;
51
+    JsonSaveFile.close();
52
+    return true;
53
+}
54
+
55
+bool JsonHelper::writeJson(JsonArray json, string path)
56
+{
57
+    if(!validatePathExtension(path))
58
+    {
59
+        return false;
60
+    }
61
+
62
+    string arrayString = "[";
63
+    size_t jsonSize = json.size();
64
+    for(size_t i = 0; i < jsonSize; ++i)
65
+    {
66
+        arrayString += "\n" + dump(json.at(i).object_items(), 1);
67
+        if(i != jsonSize - 1)
68
+        {
69
+            arrayString += ",";
70
+        }
71
+    }
72
+    arrayString += "\n]";
73
+
74
+    ofstream JsonSaveFile(path);
75
+    JsonSaveFile << arrayString;
76
+    JsonSaveFile.close();
77
+    return true;
78
+}
79
+
80
+string JsonHelper::dump(JsonObject json, int extraTab)
81
+{
82
+    string dump = Json(json).dump();
83
+    //[defensive programming] possibly check if dump returns a invalid string
84
+    string out = "";
85
+    unsigned int tabCounter = extraTab;
86
+    printTabs(out,tabCounter);
87
+    for(unsigned int i = 0; i < dump.size(); ++i)
88
+    {
89
+        if(dump[i] == '{' || dump[i] == '[')
90
+        {            
91
+            out += dump[i];
92
+            out += '\n';
93
+            ++tabCounter;
94
+            printTabs(out, tabCounter);
95
+        }
96
+        else if(dump[i] == '}' || dump[i] == ']')
97
+        {
98
+            out += '\n';
99
+            --tabCounter;
100
+            printTabs(out, tabCounter);
101
+            out += dump[i];
102
+        }
103
+        else if(dump[i] == ',')
104
+        {
105
+            out += dump[i];
106
+            out += '\n';
107
+            printTabs(out, tabCounter);
108
+            ++i; //skip blank space following comma
109
+        }
110
+        else
111
+        {
112
+            out += dump[i];
113
+        }
114
+    }
115
+    return out;
116
+}
117
+
118
+void JsonHelper::printTabs(string &out, int tabCounter)
119
+{
120
+    for(int i = 0; i < tabCounter; ++i)
121
+    {
122
+        out += '\t';
123
+    }
124
+}
125
+
126
+JsonObject JsonHelper::readJson(string path)
127
+{
128
+    std::size_t ext = path.find_last_of('.');
129
+    std::string extension = path.substr(ext+1);
130
+
131
+    if(extension.compare("json") && extension.compare("JSON"))
132
+    {
133
+        std::cout << "Fail open file, extension not valid!" << std::endl;
134
+        return JsonObject();
135
+    }
136
+
137
+    struct stat buffer;
138
+    if(stat(path.c_str(),&buffer))
139
+    {
140
+        std::cout << "Fail open file, file doesn't exist" << std::endl;
141
+        return JsonObject();
142
+    }
143
+
144
+    ifstream tfile;
145
+    string json_str;
146
+    string json_str2;
147
+    string err = "";
148
+    tfile.open(path);
149
+    while(tfile)
150
+    {
151
+        std::getline(tfile, json_str);
152
+        json_str2.append(json_str);
153
+    }
154
+
155
+    tfile.close();
156
+    size_t beginning = json_str2.find_first_of("{");
157
+    int fixchar = json_str2[json_str2.size() - 2] == '}' ? 1 : 0;
158
+    return Json::parse(json_str2.substr(beginning,json_str2.size() - fixchar),err).object_items();
159
+}
160
+
161
+JsonArray JsonHelper::readJsonArray(const string &path)
162
+{
163
+    std::size_t ext = path.find_last_of('.');
164
+    std::string extension = path.substr(ext+1);
165
+
166
+    if(extension.compare("json") && extension.compare("JSON"))
167
+    {
168
+        std::cout << "Fail open file, extension not valid!" << std::endl;
169
+        return JsonArray();
170
+    }
171
+
172
+    struct stat buffer;
173
+    if(stat(path.c_str(),&buffer))
174
+    {
175
+        std::cout << "Fail open file, file doesn't exist" << std::endl;
176
+        return JsonArray();
177
+    }
178
+
179
+    ifstream tfile;
180
+    string json_str;
181
+    string json_str2;
182
+    string err = "";
183
+    tfile.open(path);
184
+    while(tfile)
185
+    {
186
+        std::getline(tfile, json_str);
187
+        json_str2.append(json_str);
188
+    }
189
+
190
+    tfile.close();
191
+
192
+    size_t beginning = json_str2.find_first_of("[");
193
+    int fixchar = json_str2[json_str2.size() - 2] == ']' ? 1 : 0;
194
+    return Json::parse(json_str2.substr(beginning,json_str2.size() - fixchar),err).array_items();
195
+}
196
+
197
+bool JsonHelper::validatePathExtension(string &path)
198
+{
199
+
200
+    if(path.empty())
201
+    {
202
+        std::cout << "Fail saving json file" << std::endl;
203
+        return false;
204
+    }
205
+    std::size_t ext = path.find_last_of('.');
206
+    std::string realFilePath = path;
207
+    if(ext == std::string::npos)
208
+    {
209
+        realFilePath += ".json";
210
+    }
211
+    else
212
+    {
213
+        std::string extension = path.substr(ext+1);
214
+        if(extension.compare("json") && extension.compare("JSON"))
215
+        {
216
+            std::cout << "Fail saving file, extension not valid!" << std::endl;
217
+            return false;
218
+        }
219
+    }
220
+    path = realFilePath;
221
+    return true;
222
+}
223
x265_2.4.tar.gz/source/dynamicHDR10/JsonHelper.h Added
56
 
1
@@ -0,0 +1,54 @@
2
+/**
3
+ * @file                       JsonHelper.h
4
+ * @brief                      Helper class for JSON parsing
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#ifndef JSON_H
28
+#define JSON_H
29
+#include <string>
30
+#include <iostream>
31
+#include "json11/json11.h"
32
+
33
+using std::string;
34
+using namespace json11;
35
+typedef Json::object JsonObject;
36
+typedef Json::array JsonArray;
37
+
38
+class JsonHelper
39
+{
40
+public:
41
+    static JsonObject readJson(string path);
42
+    static JsonArray readJsonArray(const string &path);
43
+    static string dump(JsonArray json);
44
+    static string dump(JsonObject json, int extraTab = 0);
45
+
46
+    static bool writeJson(JsonObject json , string path);
47
+    static bool writeJson(JsonArray json, string path);
48
+    static JsonObject add(string key, string value, JsonObject &json);
49
+private:
50
+    static void printTabs(string &out, int tabCounter);
51
+    JsonObject mJson;
52
+    static bool validatePathExtension(string &path);
53
+};
54
+
55
+#endif // JSON_H
56
x265_2.4.tar.gz/source/dynamicHDR10/LICENSE.txt Added
23
 
1
@@ -0,0 +1,20 @@
2
+Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
3
+
4
+This software is the confidential and proprietary information of Samsung Electronics, Inc. ("Confidential Information").
5
+You shall not disclose such Confidential Information and shall use it only in accordance with the terms of the license agreement
6
+you entered into with Samsung.
7
+
8
+This program is free software; you can redistribute it and/or
9
+modify it under the terms of the GNU General Public License
10
+as published by the Free Software Foundation; either version 2
11
+of the License, or (at your option) any later version.
12
+
13
+This program is distributed in the hope that it will be useful,
14
+but WITHOUT ANY WARRANTY; without even the implied warranty of
15
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16
+GNU General Public License for more details.
17
+
18
+You should have received a copy of the GNU General Public License
19
+along with this program; if not, write to the Free Software
20
+Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 
21
+MA 02110-1301, USA.
22
\ No newline at end of file
23
x265_2.4.tar.gz/source/dynamicHDR10/SeiMetadataDictionary.cpp Added
115
 
1
@@ -0,0 +1,113 @@
2
+/**
3
+ * @file                       SeiMetadataDictionary.cpp
4
+ * @brief                      Defines the tagname for each metadata value in a JSON dynamic tone mapping file.
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#include "SeiMetadataDictionary.h"
28
+
29
+using namespace SeiMetadataDictionary;
30
+
31
+const std::string JsonDataKeys::LocalParameters = std::string("LocalParameters");
32
+const std::string JsonDataKeys::TargetDisplayLuminance = std::string("TargetedSystemDisplayMaximumLuminance");
33
+
34
+const std::string BezierCurveNames::TagName = std::string("BezierCurveData");
35
+const std::string BezierCurveNames::NumberOfAnchors = std::string("NumberOfAnchors");
36
+const std::string BezierCurveNames::KneePointX = std::string("KneePointX");
37
+const std::string BezierCurveNames::KneePointY = std::string("KneePointY");
38
+const std::string BezierCurveNames::Anchors[] = {std::string("Anchor0"),
39
+                                                 std::string("Anchor1"),
40
+                                                 std::string("Anchor2"),
41
+                                                 std::string("Anchor3"),
42
+                                                 std::string("Anchor4"),
43
+                                                 std::string("Anchor5"),
44
+                                                 std::string("Anchor6"),
45
+                                                 std::string("Anchor7"),
46
+                                                 std::string("Anchor8"),
47
+                                                 std::string("Anchor9"),
48
+                                                 std::string("Anchor10"),
49
+                                                 std::string("Anchor11"),
50
+                                                 std::string("Anchor12"),
51
+                                                 std::string("Anchor13")};
52
+
53
+
54
+const std::string EllipseSelectionNames::WindowUpperLeftCornerX = std::string("WindowUpperLeftCornerX");
55
+const std::string EllipseSelectionNames::WindowUpperLeftCornerY = std::string("WindowUpperLeftCornerY");
56
+const std::string EllipseSelectionNames::WindowLowerRightCornerX = std::string("WindowLowerRightCornerX");
57
+const std::string EllipseSelectionNames::WindowLowerRightCornerY = std::string("WindowLowerRightCornerY");
58
+const std::string EllipseSelectionNames::WindowData = std::string("WindowData");
59
+
60
+
61
+const std::string EllipseNames::TagName = std::string("EllipseData");
62
+const std::string EllipseNames::RotationAngle = std::string("RotationAngle");
63
+const std::string EllipseNames::CenterOfEllipseX = std::string("CenterOfEllipseX");
64
+const std::string EllipseNames::CenterOfEllipseY = std::string("CenterOfEllipseY");
65
+const std::string EllipseNames::OverlapProcessOption = std::string("OverlapProcessOption");
66
+const std::string EllipseNames::SemiMajorAxisExternalEllipse = std::string("SemimajorAxisExternalEllipse");
67
+const std::string EllipseNames::SemiMinorAxisExternalEllipse = std::string("SemiminorAxisExternalEllipse");
68
+const std::string EllipseNames::SemiMajorAxisInternalEllipse = std::string("SemimajorAxisInternalEllipse");
69
+
70
+
71
+const std::string PercentileNames::TagName = std::string("PercentileLuminance");
72
+const std::string PercentileNames::NumberOfPercentiles = std::string("NumberOfPercentiles");
73
+const std::string PercentileNames::PercentilePercentageValue[] = {std::string("PercentilePercentage0"),
74
+                                                                  std::string("PercentilePercentage1"),
75
+                                                                  std::string("PercentilePercentage2"),
76
+                                                                  std::string("PercentilePercentage3"),
77
+                                                                  std::string("PercentilePercentage4"),
78
+                                                                  std::string("PercentilePercentage5"),
79
+                                                                  std::string("PercentilePercentage6"),
80
+                                                                  std::string("PercentilePercentage7"),
81
+                                                                  std::string("PercentilePercentage8"),
82
+                                                                  std::string("PercentilePercentage9"),
83
+                                                                  std::string("PercentilePercentage10"),
84
+                                                                  std::string("PercentilePercentage11"),
85
+                                                                  std::string("PercentilePercentage12"),
86
+                                                                  std::string("PercentilePercentage13"),
87
+                                                                  std::string("PercentilePercentage14")};
88
+
89
+const std::string PercentileNames::PercentileLuminanceValue[] = {std::string("PercentileLuminance0"),
90
+                                                                  std::string("PercentileLuminance1"),
91
+                                                                  std::string("PercentileLuminance2"),
92
+                                                                  std::string("PercentileLuminance3"),
93
+                                                                  std::string("PercentileLuminance4"),
94
+                                                                  std::string("PercentileLuminance5"),
95
+                                                                  std::string("PercentileLuminance6"),
96
+                                                                  std::string("PercentileLuminance7"),
97
+                                                                  std::string("PercentileLuminance8"),
98
+                                                                  std::string("PercentileLuminance9"),
99
+                                                                  std::string("PercentileLuminance10"),
100
+                                                                  std::string("PercentileLuminance11"),
101
+                                                                  std::string("PercentileLuminance12"),
102
+                                                                  std::string("PercentileLuminance13"),
103
+                                                                  std::string("PercentileLuminance14")};
104
+
105
+
106
+
107
+const std::string LuminanceNames::TagName = std::string("LuminanceParameters");
108
+const std::string LuminanceNames::AverageRGB = std::string("AverageRGB");
109
+const std::string LuminanceNames::MaxSCL0 = std::string("MaxScl0");
110
+const std::string LuminanceNames::MaxSCL1 = std::string("MaxScl1");
111
+const std::string LuminanceNames::MaxSCL2 = std::string("MaxScl2");
112
+
113
+
114
+
115
x265_2.4.tar.gz/source/dynamicHDR10/SeiMetadataDictionary.h Added
99
 
1
@@ -0,0 +1,97 @@
2
+/**
3
+ * @file                       SeiMetadataDictionary.h
4
+ * @brief                      Defines the tagname for each metadata value in a JSON dynamic tone mapping file.
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#ifndef SEIMETADATADICTIONARY_H
28
+#define SEIMETADATADICTIONARY_H
29
+
30
+#include "SeiMetadataDictionary.h"
31
+
32
+#include <string>
33
+
34
+namespace SeiMetadataDictionary
35
+{
36
+
37
+    class JsonDataKeys
38
+    {
39
+        public:
40
+        static const std::string LocalParameters;
41
+        static const std::string TargetDisplayLuminance;
42
+    };
43
+
44
+    //Bezier Curve Data
45
+    class BezierCurveNames
46
+    {
47
+        public:
48
+        static const std::string TagName;
49
+        static const std::string NumberOfAnchors;
50
+        static const std::string KneePointX;
51
+        static const std::string KneePointY;
52
+        static const std::string Anchors[14];
53
+    };
54
+    //Ellipse Selection Data
55
+    class EllipseSelectionNames
56
+    {
57
+        public:
58
+        static const std::string WindowUpperLeftCornerX;
59
+        static const std::string WindowUpperLeftCornerY;
60
+        static const std::string WindowLowerRightCornerX;
61
+        static const std::string WindowLowerRightCornerY;
62
+        static const std::string WindowData;
63
+    };
64
+    //Ellipse Data
65
+    class EllipseNames
66
+    {
67
+        public:
68
+        static const std::string TagName;
69
+        static const std::string RotationAngle;
70
+        static const std::string CenterOfEllipseX;
71
+        static const std::string CenterOfEllipseY;
72
+        static const std::string OverlapProcessOption;
73
+        static const std::string SemiMajorAxisExternalEllipse;
74
+        static const std::string SemiMinorAxisExternalEllipse;
75
+        static const std::string SemiMajorAxisInternalEllipse;
76
+    };
77
+    //Percentile Luminance
78
+    class PercentileNames
79
+    {
80
+        public:
81
+        static const std::string TagName;
82
+        static const std::string NumberOfPercentiles;
83
+        static const std::string PercentilePercentageValue[15];
84
+        static const std::string PercentileLuminanceValue[15];
85
+    };
86
+    //Luminance Parameters
87
+    class LuminanceNames
88
+    {
89
+        public:
90
+        static const std::string TagName;
91
+        static const std::string AverageRGB;
92
+        static const std::string MaxSCL0;
93
+        static const std::string MaxSCL1;
94
+        static const std::string MaxSCL2;
95
+    };
96
+}
97
+
98
+#endif // SEIMETADATADICTIONARY_H
99
x265_2.4.tar.gz/source/dynamicHDR10/api.cpp Added
81
 
1
@@ -0,0 +1,79 @@
2
+/**
3
+ * @file                       api.cpp
4
+ * @brief                      Implementation of hdr10plus API functions.
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#include "hdr10plus.h"
28
+#include "metadataFromJson.h"
29
+
30
+bool hdr10plus_json_to_frame_cim(const char* path, uint32_t frameNumber, uint8_t *&cim)
31
+{
32
+      metadataFromJson meta;
33
+      return meta.frameMetadataFromJson(path,
34
+                                        frameNumber,
35
+                                        cim);
36
+}
37
+
38
+int hdr10plus_json_to_movie_cim(const char* path, uint8_t **&cim)
39
+{
40
+      metadataFromJson meta;
41
+      return meta.movieMetadataFromJson(path, cim);
42
+}
43
+
44
+bool hdr10plus_json_to_frame_eif(const char* path, uint32_t frameNumber, uint8_t *&eif)
45
+{
46
+    metadataFromJson meta;
47
+    return meta.extendedInfoFrameMetadataFromJson(path,
48
+                                                  frameNumber,
49
+                                                  eif);
50
+}
51
+
52
+int hdr10plus_json_to_movie_eif(const char* path, uint8_t **&eif)
53
+{
54
+    metadataFromJson meta;
55
+    return meta.movieExtendedInfoFrameMetadataFromJson(path, eif);
56
+}
57
+
58
+
59
+void hdr10plus_clear_movie(uint8_t **&metadata, const int numberOfFrames)
60
+{
61
+    if(metadata)
62
+    {
63
+        metadataFromJson meta;
64
+        meta.clear(metadata, numberOfFrames);
65
+    }
66
+}
67
+
68
+static const hdr10plus_api libapi =
69
+{
70
+    &hdr10plus_json_to_frame_cim,
71
+    &hdr10plus_json_to_movie_cim,
72
+    &hdr10plus_json_to_frame_eif,
73
+    &hdr10plus_json_to_movie_eif,
74
+    &hdr10plus_clear_movie,
75
+};
76
+
77
+const hdr10plus_api* hdr10plus_api_get()
78
+{
79
+    return &libapi;
80
+}
81
x265_2.4.tar.gz/source/dynamicHDR10/hdr10plus.h Added
103
 
1
@@ -0,0 +1,101 @@
2
+/**
3
+ * @file                       hdr10plus.h
4
+ * @brief                      Definition of hdr10plus functions.
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#include <stdint.h>
28
+
29
+#ifndef HDR10PLUS_H
30
+#define HDR10PLUS_H
31
+
32
+
33
+/* hdr10plus_json_to_frame_cim:
34
+ *      Parses the json file containing the  Creative Intent Metadata DTM for a frame of 
35
+ *      video into a bytestream to be encoded into the resulting video stream. 
36
+ *      path is the file path of the JSON file containing the DTM for the video.
37
+ *      frameNumber is the number of the frame to get the metadata for.
38
+ *      cim will get filled with the byte array containing the actual metadata.
39
+ *      Returns true in case of success.
40
+ */
41
+bool hdr10plus_json_to_frame_cim(const char* path, uint32_t frameNumber, uint8_t *&cim);
42
+
43
+/* hdr10plus_json_to_movie_cim:
44
+ *      Parses the json file containing the Creative Intent Metadata DTM for the video 
45
+ *      into a bytestream to be encoded into the resulting video stream. 
46
+ *      path is the file path of the JSON file containing the DTM for the video.
47
+ *      frameNumber is the number of the frame to get the metadata for.
48
+ *      cim will get filled with the byte array containing the actual metadata.
49
+ *      return int: number of frames in the movie, -1 if the process fails to obtain the metadata. 
50
+ */
51
+int hdr10plus_json_to_movie_cim(const char* path, uint8_t **&cim);
52
+
53
+/* hdr10plus_json_to_frame_eif:
54
+*      Parses the json file containing the Extended InfoFrame metadata for a frame of video
55
+*      into a bytestream to be encoded into the resulting video stream.
56
+*      path is the file path of the JSON file containing the Extended InfoFrame metadata for the video.
57
+*      frameNumber is the number of the frame to get the metadata for.
58
+*      Extended InfoFrame will get filled with the byte array containing the actual metadata.
59
+*      Returns true in case of success.
60
+*/
61
+bool hdr10plus_json_to_frame_eif(const char* path, uint32_t frameNumber, uint8_t *&eif);
62
+
63
+/* hdr10plus_json_to_movie_eif:
64
+*      Parses the json file containing the Extended InfoFrame metadata for the video
65
+*      into a bytestream to be encoded into the resulting video stream.
66
+*      path is the file path of the JSON file containing the Extended InfoFrame metadata for the video.
67
+*      frameNumber is the number of the frame to get the metadata for.
68
+*      cim will get filled with the byte array containing the actual metadata.
69
+*      return int: number of frames in the movie, -1 if the process fails to obtain the metadata.
70
+*/
71
+int hdr10plus_json_to_movie_eif(const char* path, uint8_t **&eif);
72
+
73
+
74
+/* hdr10plus_clear_movie_cim:
75
+*       This function clears the allocated memory for the movie metadata array
76
+*       clear: Clears the memory of the given array and size.
77
+*       metadata: metadata array to be cleared.
78
+*       numberOfFrames: number of frames in the metadata array.
79
+* @return
80
+*/
81
+
82
+void hdr10plus_clear_movie(uint8_t**& metadata, const int numberOfFrames);
83
+
84
+
85
+typedef struct hdr10plus_api
86
+{
87
+    /* hdr10plus public API functions, documented above with hdr10plus_ prefixes */
88
+    bool          (*hdr10plus_json_to_frame_cim)(const char *, uint32_t, uint8_t *&);
89
+    int           (*hdr10plus_json_to_movie_cim)(const char *, uint8_t **&);
90
+    bool          (*hdr10plus_json_to_frame_eif)(const char *, uint32_t, uint8_t *&);
91
+    int           (*hdr10plus_json_to_movie_eif)(const char *, uint8_t **&);
92
+    void          (*hdr10plus_clear_movie)(uint8_t **&, const int);
93
+} hdr10plus_api;
94
+
95
+/* hdr10plus_api:
96
+ *   Retrieve the programming interface for the linked hdr10plus library.
97
+ */
98
+const hdr10plus_api* hdr10plus_api_get();
99
+
100
+
101
+#endif // HDR10PLUS_H
102
+
103
x265_2.4.tar.gz/source/dynamicHDR10/json11/LICENSE.txt Added
21
 
1
@@ -0,0 +1,19 @@
2
+Copyright (c) 2013 Dropbox, Inc.
3
+
4
+Permission is hereby granted, free of charge, to any person obtaining a copy
5
+of this software and associated documentation files (the "Software"), to deal
6
+in the Software without restriction, including without limitation the rights
7
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+copies of the Software, and to permit persons to whom the Software is
9
+furnished to do so, subject to the following conditions:
10
+
11
+The above copyright notice and this permission notice shall be included in
12
+all copies or substantial portions of the Software.
13
+
14
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20
+THE SOFTWARE.
21
x265_2.4.tar.gz/source/dynamicHDR10/json11/json11.cpp Added
782
 
1
@@ -0,0 +1,780 @@
2
+/* Copyright (c) 2013 Dropbox, Inc.
3
+ *
4
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ * of this software and associated documentation files (the "Software"), to deal
6
+ * in the Software without restriction, including without limitation the rights
7
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ * copies of the Software, and to permit persons to whom the Software is
9
+ * furnished to do so, subject to the following conditions:
10
+ *
11
+ * The above copyright notice and this permission notice shall be included in
12
+ * all copies or substantial portions of the Software.
13
+ *
14
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20
+ * THE SOFTWARE.
21
+ */
22
+
23
+#include "json11.h"
24
+#include <cassert>
25
+#include <cmath>
26
+#include <cstdlib>
27
+#include <cstdio>
28
+#include <limits>
29
+
30
+namespace json11 {
31
+
32
+static const int max_depth = 200;
33
+
34
+using std::string;
35
+using std::vector;
36
+using std::map;
37
+using std::make_shared;
38
+using std::initializer_list;
39
+using std::move;
40
+
41
+/* * * * * * * * * * * * * * * * * * * *
42
+ * Serialization
43
+ */
44
+
45
+static void dump(std::nullptr_t, string &out) {
46
+    out += "null";
47
+}
48
+
49
+static void dump(double value, string &out) {
50
+    if (std::isfinite(value)) {
51
+        char buf[32];
52
+        snprintf(buf, sizeof buf, "%.17g", value);
53
+        out += buf;
54
+    } else {
55
+        out += "null";
56
+    }
57
+}
58
+
59
+static void dump(int value, string &out) {
60
+    char buf[32];
61
+    snprintf(buf, sizeof buf, "%d", value);
62
+    out += buf;
63
+}
64
+
65
+static void dump(bool value, string &out) {
66
+    out += value ? "true" : "false";
67
+}
68
+
69
+static void dump(const string &value, string &out) {
70
+    out += '"';
71
+    for (size_t i = 0; i < value.length(); i++) {
72
+        const char ch = value[i];
73
+        if (ch == '\\') {
74
+            out += "\\\\";
75
+        } else if (ch == '"') {
76
+            out += "\\\"";
77
+        } else if (ch == '\b') {
78
+            out += "\\b";
79
+        } else if (ch == '\f') {
80
+            out += "\\f";
81
+        } else if (ch == '\n') {
82
+            out += "\\n";
83
+        } else if (ch == '\r') {
84
+            out += "\\r";
85
+        } else if (ch == '\t') {
86
+            out += "\\t";
87
+        } else if (static_cast<uint8_t>(ch) <= 0x1f) {
88
+            char buf[8];
89
+            snprintf(buf, sizeof buf, "\\u%04x", ch);
90
+            out += buf;
91
+        } else if (static_cast<uint8_t>(ch) == 0xe2 && static_cast<uint8_t>(value[i+1]) == 0x80
92
+                   && static_cast<uint8_t>(value[i+2]) == 0xa8) {
93
+            out += "\\u2028";
94
+            i += 2;
95
+        } else if (static_cast<uint8_t>(ch) == 0xe2 && static_cast<uint8_t>(value[i+1]) == 0x80
96
+                   && static_cast<uint8_t>(value[i+2]) == 0xa9) {
97
+            out += "\\u2029";
98
+            i += 2;
99
+        } else {
100
+            out += ch;
101
+        }
102
+    }
103
+    out += '"';
104
+}
105
+
106
+static void dump(const Json::array &values, string &out) {
107
+    bool first = true;
108
+    out += "[";
109
+    for (const auto &value : values) {
110
+        if (!first)
111
+            out += ", ";
112
+        value.dump(out);
113
+        first = false;
114
+    }
115
+    out += "]";
116
+}
117
+
118
+static void dump(const Json::object &values, string &out) {
119
+    bool first = true;
120
+    out += "{";
121
+    for (const auto &kv : values) {
122
+        if (!first)
123
+            out += ", ";
124
+        dump(kv.first, out);
125
+        out += ": ";
126
+        kv.second.dump(out);
127
+        first = false;
128
+    }
129
+    out += "}";
130
+}
131
+
132
+void Json::dump(string &out) const {
133
+    m_ptr->dump(out);
134
+}
135
+
136
+/* * * * * * * * * * * * * * * * * * * *
137
+ * Value wrappers
138
+ */
139
+
140
+template <Json::Type tag, typename T>
141
+class Value : public JsonValue {
142
+protected:
143
+
144
+    // Constructors
145
+    explicit Value(const T &value) : m_value(value) {}
146
+    explicit Value(T &&value)      : m_value(move(value)) {}
147
+
148
+    // Get type tag
149
+    Json::Type type() const override {
150
+        return tag;
151
+    }
152
+
153
+    // Comparisons
154
+    bool equals(const JsonValue * other) const override {
155
+        return m_value == static_cast<const Value<tag, T> *>(other)->m_value;
156
+    }
157
+    bool less(const JsonValue * other) const override {
158
+        return m_value < static_cast<const Value<tag, T> *>(other)->m_value;
159
+    }
160
+
161
+    const T m_value;
162
+    void dump(string &out) const override { json11::dump(m_value, out); }
163
+};
164
+
165
+class JsonDouble final : public Value<Json::NUMBER, double> {
166
+    double number_value() const override { return m_value; }
167
+    int int_value() const override { return static_cast<int>(m_value); }
168
+    bool equals(const JsonValue * other) const override { return m_value == other->number_value(); }
169
+    bool less(const JsonValue * other)   const override { return m_value <  other->number_value(); }
170
+public:
171
+    explicit JsonDouble(double value) : Value(value) {}
172
+};
173
+
174
+class JsonInt final : public Value<Json::NUMBER, int> {
175
+    double number_value() const override { return m_value; }
176
+    int int_value() const override { return m_value; }
177
+    bool equals(const JsonValue * other) const override { return m_value == other->number_value(); }
178
+    bool less(const JsonValue * other)   const override { return m_value <  other->number_value(); }
179
+public:
180
+    explicit JsonInt(int value) : Value(value) {}
181
+};
182
+
183
+class JsonBoolean final : public Value<Json::BOOL, bool> {
184
+    bool bool_value() const override { return m_value; }
185
+public:
186
+    explicit JsonBoolean(bool value) : Value(value) {}
187
+};
188
+
189
+class JsonString final : public Value<Json::STRING, string> {
190
+    const string &string_value() const override { return m_value; }
191
+public:
192
+    explicit JsonString(const string &value) : Value(value) {}
193
+    explicit JsonString(string &&value)      : Value(move(value)) {}
194
+};
195
+
196
+class JsonArray final : public Value<Json::ARRAY, Json::array> {
197
+    const Json::array &array_items() const override { return m_value; }
198
+    const Json & operator[](size_t i) const override;
199
+public:
200
+    explicit JsonArray(const Json::array &value) : Value(value) {}
201
+    explicit JsonArray(Json::array &&value)      : Value(move(value)) {}
202
+};
203
+
204
+class JsonObject final : public Value<Json::OBJECT, Json::object> {
205
+    const Json::object &object_items() const override { return m_value; }
206
+    const Json & operator[](const string &key) const override;
207
+public:
208
+    explicit JsonObject(const Json::object &value) : Value(value) {}
209
+    explicit JsonObject(Json::object &&value)      : Value(move(value)) {}
210
+};
211
+
212
+class JsonNull final : public Value<Json::NUL, std::nullptr_t> {
213
+public:
214
+    JsonNull() : Value(nullptr) {}
215
+};
216
+
217
+/* * * * * * * * * * * * * * * * * * * *
218
+ * Static globals - static-init-safe
219
+ */
220
+struct Statics {
221
+    const std::shared_ptr<JsonValue> null = make_shared<JsonNull>();
222
+    const std::shared_ptr<JsonValue> t = make_shared<JsonBoolean>(true);
223
+    const std::shared_ptr<JsonValue> f = make_shared<JsonBoolean>(false);
224
+    const string empty_string;
225
+    const vector<Json> empty_vector;
226
+    const map<string, Json> empty_map;
227
+    Statics() {}
228
+};
229
+
230
+static const Statics & statics() {
231
+    static const Statics s {};
232
+    return s;
233
+}
234
+
235
+static const Json & static_null() {
236
+    // This has to be separate, not in Statics, because Json() accesses statics().null.
237
+    static const Json json_null;
238
+    return json_null;
239
+}
240
+
241
+/* * * * * * * * * * * * * * * * * * * *
242
+ * Constructors
243
+ */
244
+
245
+Json::Json() noexcept                  : m_ptr(statics().null) {}
246
+Json::Json(std::nullptr_t) noexcept    : m_ptr(statics().null) {}
247
+Json::Json(double value)               : m_ptr(make_shared<JsonDouble>(value)) {}
248
+Json::Json(int value)                  : m_ptr(make_shared<JsonInt>(value)) {}
249
+Json::Json(bool value)                 : m_ptr(value ? statics().t : statics().f) {}
250
+Json::Json(const string &value)        : m_ptr(make_shared<JsonString>(value)) {}
251
+Json::Json(string &&value)             : m_ptr(make_shared<JsonString>(move(value))) {}
252
+Json::Json(const char * value)         : m_ptr(make_shared<JsonString>(value)) {}
253
+Json::Json(const Json::array &values)  : m_ptr(make_shared<JsonArray>(values)) {}
254
+Json::Json(Json::array &&values)       : m_ptr(make_shared<JsonArray>(move(values))) {}
255
+Json::Json(const Json::object &values) : m_ptr(make_shared<JsonObject>(values)) {}
256
+Json::Json(Json::object &&values)      : m_ptr(make_shared<JsonObject>(move(values))) {}
257
+
258
+/* * * * * * * * * * * * * * * * * * * *
259
+ * Accessors
260
+ */
261
+
262
+Json::Type Json::type()                           const { return m_ptr->type();         }
263
+double Json::number_value()                       const { return m_ptr->number_value(); }
264
+int Json::int_value()                             const { return m_ptr->int_value();    }
265
+bool Json::bool_value()                           const { return m_ptr->bool_value();   }
266
+const string & Json::string_value()               const { return m_ptr->string_value(); }
267
+const vector<Json> & Json::array_items()          const { return m_ptr->array_items();  }
268
+const map<string, Json> & Json::object_items()    const { return m_ptr->object_items(); }
269
+const Json & Json::operator[] (size_t i)          const { return (*m_ptr)[i];           }
270
+const Json & Json::operator[] (const string &key) const { return (*m_ptr)[key];         }
271
+
272
+double                    JsonValue::number_value()              const { return 0; }
273
+int                       JsonValue::int_value()                 const { return 0; }
274
+bool                      JsonValue::bool_value()                const { return false; }
275
+const string &            JsonValue::string_value()              const { return statics().empty_string; }
276
+const vector<Json> &      JsonValue::array_items()               const { return statics().empty_vector; }
277
+const map<string, Json> & JsonValue::object_items()              const { return statics().empty_map; }
278
+const Json &              JsonValue::operator[] (size_t)         const { return static_null(); }
279
+const Json &              JsonValue::operator[] (const string &) const { return static_null(); }
280
+
281
+const Json & JsonObject::operator[] (const string &key) const {
282
+    auto iter = m_value.find(key);
283
+    return (iter == m_value.end()) ? static_null() : iter->second;
284
+}
285
+const Json & JsonArray::operator[] (size_t i) const {
286
+    if (i >= m_value.size()) return static_null();
287
+    else return m_value[i];
288
+}
289
+
290
+/* * * * * * * * * * * * * * * * * * * *
291
+ * Comparison
292
+ */
293
+
294
+bool Json::operator== (const Json &other) const {
295
+    if (m_ptr->type() != other.m_ptr->type())
296
+        return false;
297
+
298
+    return m_ptr->equals(other.m_ptr.get());
299
+}
300
+
301
+bool Json::operator< (const Json &other) const {
302
+    if (m_ptr->type() != other.m_ptr->type())
303
+        return m_ptr->type() < other.m_ptr->type();
304
+
305
+    return m_ptr->less(other.m_ptr.get());
306
+}
307
+
308
+/* * * * * * * * * * * * * * * * * * * *
309
+ * Parsing
310
+ */
311
+
312
+/* esc(c)
313
+ *
314
+ * Format char c suitable for printing in an error message.
315
+ */
316
+static inline string esc(char c) {
317
+    char buf[12];
318
+    if (static_cast<uint8_t>(c) >= 0x20 && static_cast<uint8_t>(c) <= 0x7f) {
319
+        snprintf(buf, sizeof buf, "'%c' (%d)", c, c);
320
+    } else {
321
+        snprintf(buf, sizeof buf, "(%d)", c);
322
+    }
323
+    return string(buf);
324
+}
325
+
326
+static inline bool in_range(long x, long lower, long upper) {
327
+    return (x >= lower && x <= upper);
328
+}
329
+
330
+namespace {
331
+/* JsonParser
332
+ *
333
+ * Object that tracks all state of an in-progress parse.
334
+ */
335
+struct JsonParser final {
336
+
337
+    /* State
338
+     */
339
+    const string &str;
340
+    size_t i;
341
+    string &err;
342
+    bool failed;
343
+    const JsonParse strategy;
344
+
345
+    /* fail(msg, err_ret = Json())
346
+     *
347
+     * Mark this parse as failed.
348
+     */
349
+    Json fail(string &&msg) {
350
+        return fail(move(msg), Json());
351
+    }
352
+
353
+    template <typename T>
354
+    T fail(string &&msg, const T err_ret) {
355
+        if (!failed)
356
+            err = std::move(msg);
357
+        failed = true;
358
+        return err_ret;
359
+    }
360
+
361
+    /* consume_whitespace()
362
+     *
363
+     * Advance until the current character is non-whitespace.
364
+     */
365
+    void consume_whitespace() {
366
+        while (str[i] == ' ' || str[i] == '\r' || str[i] == '\n' || str[i] == '\t')
367
+            i++;
368
+    }
369
+
370
+    /* consume_comment()
371
+     *
372
+     * Advance comments (c-style inline and multiline).
373
+     */
374
+    bool consume_comment() {
375
+      bool comment_found = false;
376
+      if (str[i] == '/') {
377
+        i++;
378
+        if (i == str.size())
379
+          return fail("unexpected end of input inside comment", false);
380
+        if (str[i] == '/') { // inline comment
381
+          i++;
382
+          if (i == str.size())
383
+            return fail("unexpected end of input inside inline comment", false);
384
+          // advance until next line
385
+          while (str[i] != '\n') {
386
+            i++;
387
+            if (i == str.size())
388
+              return fail("unexpected end of input inside inline comment", false);
389
+          }
390
+          comment_found = true;
391
+        }
392
+        else if (str[i] == '*') { // multiline comment
393
+          i++;
394
+          if (i > str.size()-2)
395
+            return fail("unexpected end of input inside multi-line comment", false);
396
+          // advance until closing tokens
397
+          while (!(str[i] == '*' && str[i+1] == '/')) {
398
+            i++;
399
+            if (i > str.size()-2)
400
+              return fail(
401
+                "unexpected end of input inside multi-line comment", false);
402
+          }
403
+          i += 2;
404
+          if (i == str.size())
405
+            return fail(
406
+              "unexpected end of input inside multi-line comment", false);
407
+          comment_found = true;
408
+        }
409
+        else
410
+          return fail("malformed comment", false);
411
+      }
412
+      return comment_found;
413
+    }
414
+
415
+    /* consume_garbage()
416
+     *
417
+     * Advance until the current character is non-whitespace and non-comment.
418
+     */
419
+    void consume_garbage() {
420
+      consume_whitespace();
421
+      if(strategy == JsonParse::COMMENTS) {
422
+        bool comment_found = false;
423
+        do {
424
+          comment_found = consume_comment();
425
+          consume_whitespace();
426
+        }
427
+        while(comment_found);
428
+      }
429
+    }
430
+
431
+    /* get_next_token()
432
+     *
433
+     * Return the next non-whitespace character. If the end of the input is reached,
434
+     * flag an error and return 0.
435
+     */
436
+    char get_next_token() {
437
+        consume_garbage();
438
+        if (i == str.size())
439
+            return fail("unexpected end of input", 0);
440
+
441
+        return str[i++];
442
+    }
443
+
444
+    /* encode_utf8(pt, out)
445
+     *
446
+     * Encode pt as UTF-8 and add it to out.
447
+     */
448
+    void encode_utf8(long pt, string & out) {
449
+        if (pt < 0)
450
+            return;
451
+
452
+        if (pt < 0x80) {
453
+            out += static_cast<char>(pt);
454
+        } else if (pt < 0x800) {
455
+            out += static_cast<char>((pt >> 6) | 0xC0);
456
+            out += static_cast<char>((pt & 0x3F) | 0x80);
457
+        } else if (pt < 0x10000) {
458
+            out += static_cast<char>((pt >> 12) | 0xE0);
459
+            out += static_cast<char>(((pt >> 6) & 0x3F) | 0x80);
460
+            out += static_cast<char>((pt & 0x3F) | 0x80);
461
+        } else {
462
+            out += static_cast<char>((pt >> 18) | 0xF0);
463
+            out += static_cast<char>(((pt >> 12) & 0x3F) | 0x80);
464
+            out += static_cast<char>(((pt >> 6) & 0x3F) | 0x80);
465
+            out += static_cast<char>((pt & 0x3F) | 0x80);
466
+        }
467
+    }
468
+
469
+    /* parse_string()
470
+     *
471
+     * Parse a string, starting at the current position.
472
+     */
473
+    string parse_string() {
474
+        string out;
475
+        long last_escaped_codepoint = -1;
476
+        while (true) {
477
+            if (i == str.size())
478
+                return fail("unexpected end of input in string", "");
479
+
480
+            char ch = str[i++];
481
+
482
+            if (ch == '"') {
483
+                encode_utf8(last_escaped_codepoint, out);
484
+                return out;
485
+            }
486
+
487
+            if (in_range(ch, 0, 0x1f))
488
+                return fail("unescaped " + esc(ch) + " in string", "");
489
+
490
+            // The usual case: non-escaped characters
491
+            if (ch != '\\') {
492
+                encode_utf8(last_escaped_codepoint, out);
493
+                last_escaped_codepoint = -1;
494
+                out += ch;
495
+                continue;
496
+            }
497
+
498
+            // Handle escapes
499
+            if (i == str.size())
500
+                return fail("unexpected end of input in string", "");
501
+
502
+            ch = str[i++];
503
+
504
+            if (ch == 'u') {
505
+                // Extract 4-byte escape sequence
506
+                string esc = str.substr(i, 4);
507
+                // Explicitly check length of the substring. The following loop
508
+                // relies on std::string returning the terminating NUL when
509
+                // accessing str[length]. Checking here reduces brittleness.
510
+                if (esc.length() < 4) {
511
+                    return fail("bad \\u escape: " + esc, "");
512
+                }
513
+                for (int j = 0; j < 4; j++) {
514
+                    if (!in_range(esc[j], 'a', 'f') && !in_range(esc[j], 'A', 'F')
515
+                            && !in_range(esc[j], '0', '9'))
516
+                        return fail("bad \\u escape: " + esc, "");
517
+                }
518
+
519
+                long codepoint = strtol(esc.data(), nullptr, 16);
520
+
521
+                // JSON specifies that characters outside the BMP shall be encoded as a pair
522
+                // of 4-hex-digit \u escapes encoding their surrogate pair components. Check
523
+                // whether we're in the middle of such a beast: the previous codepoint was an
524
+                // escaped lead (high) surrogate, and this is a trail (low) surrogate.
525
+                if (in_range(last_escaped_codepoint, 0xD800, 0xDBFF)
526
+                        && in_range(codepoint, 0xDC00, 0xDFFF)) {
527
+                    // Reassemble the two surrogate pairs into one astral-plane character, per
528
+                    // the UTF-16 algorithm.
529
+                    encode_utf8((((last_escaped_codepoint - 0xD800) << 10)
530
+                                 | (codepoint - 0xDC00)) + 0x10000, out);
531
+                    last_escaped_codepoint = -1;
532
+                } else {
533
+                    encode_utf8(last_escaped_codepoint, out);
534
+                    last_escaped_codepoint = codepoint;
535
+                }
536
+
537
+                i += 4;
538
+                continue;
539
+            }
540
+
541
+            encode_utf8(last_escaped_codepoint, out);
542
+            last_escaped_codepoint = -1;
543
+
544
+            if (ch == 'b') {
545
+                out += '\b';
546
+            } else if (ch == 'f') {
547
+                out += '\f';
548
+            } else if (ch == 'n') {
549
+                out += '\n';
550
+            } else if (ch == 'r') {
551
+                out += '\r';
552
+            } else if (ch == 't') {
553
+                out += '\t';
554
+            } else if (ch == '"' || ch == '\\' || ch == '/') {
555
+                out += ch;
556
+            } else {
557
+                return fail("invalid escape character " + esc(ch), "");
558
+            }
559
+        }
560
+    }
561
+
562
+    /* parse_number()
563
+     *
564
+     * Parse a double.
565
+     */
566
+    Json parse_number() {
567
+        size_t start_pos = i;
568
+
569
+        if (str[i] == '-')
570
+            i++;
571
+
572
+        // Integer part
573
+        if (str[i] == '0') {
574
+            i++;
575
+            if (in_range(str[i], '0', '9'))
576
+                return fail("leading 0s not permitted in numbers");
577
+        } else if (in_range(str[i], '1', '9')) {
578
+            i++;
579
+            while (in_range(str[i], '0', '9'))
580
+                i++;
581
+        } else {
582
+            return fail("invalid " + esc(str[i]) + " in number");
583
+        }
584
+
585
+        if (str[i] != '.' && str[i] != 'e' && str[i] != 'E'
586
+                && (i - start_pos) <= static_cast<size_t>(std::numeric_limits<int>::digits10)) {
587
+            return std::atoi(str.c_str() + start_pos);
588
+        }
589
+
590
+        // Decimal part
591
+        if (str[i] == '.') {
592
+            i++;
593
+            if (!in_range(str[i], '0', '9'))
594
+                return fail("at least one digit required in fractional part");
595
+
596
+            while (in_range(str[i], '0', '9'))
597
+                i++;
598
+        }
599
+
600
+        // Exponent part
601
+        if (str[i] == 'e' || str[i] == 'E') {
602
+            i++;
603
+
604
+            if (str[i] == '+' || str[i] == '-')
605
+                i++;
606
+
607
+            if (!in_range(str[i], '0', '9'))
608
+                return fail("at least one digit required in exponent");
609
+
610
+            while (in_range(str[i], '0', '9'))
611
+                i++;
612
+        }
613
+
614
+        return std::strtod(str.c_str() + start_pos, nullptr);
615
+    }
616
+
617
+    /* expect(str, res)
618
+     *
619
+     * Expect that 'str' starts at the character that was just read. If it does, advance
620
+     * the input and return res. If not, flag an error.
621
+     */
622
+    Json expect(const string &expected, Json res) {
623
+        assert(i != 0);
624
+        i--;
625
+        if (str.compare(i, expected.length(), expected) == 0) {
626
+            i += expected.length();
627
+            return res;
628
+        } else {
629
+            return fail("parse error: expected " + expected + ", got " + str.substr(i, expected.length()));
630
+        }
631
+    }
632
+
633
+    /* parse_json()
634
+     *
635
+     * Parse a JSON object.
636
+     */
637
+    Json parse_json(int depth) {
638
+        if (depth > max_depth) {
639
+            return fail("exceeded maximum nesting depth");
640
+        }
641
+
642
+        char ch = get_next_token();
643
+        if (failed)
644
+            return Json();
645
+
646
+        if (ch == '-' || (ch >= '0' && ch <= '9')) {
647
+            i--;
648
+            return parse_number();
649
+        }
650
+
651
+        if (ch == 't')
652
+            return expect("true", true);
653
+
654
+        if (ch == 'f')
655
+            return expect("false", false);
656
+
657
+        if (ch == 'n')
658
+            return expect("null", Json());
659
+
660
+        if (ch == '"')
661
+            return parse_string();
662
+
663
+        if (ch == '{') {
664
+            map<string, Json> data;
665
+            ch = get_next_token();
666
+            if (ch == '}')
667
+                return data;
668
+
669
+            while (1) {
670
+                if (ch != '"')
671
+                    return fail("expected '\"' in object, got " + esc(ch));
672
+
673
+                string key = parse_string();
674
+                if (failed)
675
+                    return Json();
676
+
677
+                ch = get_next_token();
678
+                if (ch != ':')
679
+                    return fail("expected ':' in object, got " + esc(ch));
680
+
681
+                data[std::move(key)] = parse_json(depth + 1);
682
+                if (failed)
683
+                    return Json();
684
+
685
+                ch = get_next_token();
686
+                if (ch == '}')
687
+                    break;
688
+                if (ch != ',')
689
+                    return fail("expected ',' in object, got " + esc(ch));
690
+
691
+                ch = get_next_token();
692
+            }
693
+            return data;
694
+        }
695
+
696
+        if (ch == '[') {
697
+            vector<Json> data;
698
+            ch = get_next_token();
699
+            if (ch == ']')
700
+                return data;
701
+
702
+            while (1) {
703
+                i--;
704
+                data.push_back(parse_json(depth + 1));
705
+                if (failed)
706
+                    return Json();
707
+
708
+                ch = get_next_token();
709
+                if (ch == ']')
710
+                    break;
711
+                if (ch != ',')
712
+                    return fail("expected ',' in list, got " + esc(ch));
713
+
714
+                ch = get_next_token();
715
+                (void)ch;
716
+            }
717
+            return data;
718
+        }
719
+
720
+        return fail("expected value, got " + esc(ch));
721
+    }
722
+};
723
+}//namespace {
724
+
725
+Json Json::parse(const string &in, string &err, JsonParse strategy) {
726
+    JsonParser parser { in, 0, err, false, strategy };
727
+    Json result = parser.parse_json(0);
728
+
729
+    // Check for any trailing garbage
730
+    parser.consume_garbage();
731
+    if (parser.i != in.size())
732
+        return parser.fail("unexpected trailing " + esc(in[parser.i]));
733
+
734
+    return result;
735
+}
736
+
737
+// Documented in json11.hpp
738
+vector<Json> Json::parse_multi(const string &in,
739
+                               std::string::size_type &parser_stop_pos,
740
+                               string &err,
741
+                               JsonParse strategy) {
742
+    JsonParser parser { in, 0, err, false, strategy };
743
+    parser_stop_pos = 0;
744
+    vector<Json> json_vec;
745
+    while (parser.i != in.size() && !parser.failed) {
746
+        json_vec.push_back(parser.parse_json(0));
747
+        // Check for another object
748
+        parser.consume_garbage();
749
+        if (!parser.failed)
750
+            parser_stop_pos = parser.i;
751
+    }
752
+    return json_vec;
753
+}
754
+
755
+/* * * * * * * * * * * * * * * * * * * *
756
+ * Shape-checking
757
+ */
758
+
759
+bool Json::has_shape(const shape & types, string & err) const {
760
+    if (!is_object()) {
761
+        err = "expected JSON object, got " + dump();
762
+        return false;
763
+    }
764
+
765
+    for (auto & item : types) {
766
+        if ((*this)[item.first].type() != item.second) {
767
+            err = "bad type for " + item.first + " in " + dump();
768
+            return false;
769
+        }
770
+    }
771
+
772
+    return true;
773
+}
774
+//void Json::add(std::string &key, std::string value)
775
+//{
776
+//    (*m_ptr)[key] = value;
777
+//}
778
+
779
+} // namespace json11
780
+
781
+
782
x265_2.4.tar.gz/source/dynamicHDR10/json11/json11.h Added
237
 
1
@@ -0,0 +1,235 @@
2
+/* json11
3
+ *
4
+ * json11 is a tiny JSON library for C++11, providing JSON parsing and serialization.
5
+ *
6
+ * The core object provided by the library is json11::Json. A Json object represents any JSON
7
+ * value: null, bool, number (int or double), string (std::string), array (std::vector), or
8
+ * object (std::map).
9
+ *
10
+ * Json objects act like values: they can be assigned, copied, moved, compared for equality or
11
+ * order, etc. There are also helper methods Json::dump, to serialize a Json to a string, and
12
+ * Json::parse (static) to parse a std::string as a Json object.
13
+ *
14
+ * Internally, the various types of Json object are represented by the JsonValue class
15
+ * hierarchy.
16
+ *
17
+ * A note on numbers - JSON specifies the syntax of number formatting but not its semantics,
18
+ * so some JSON implementations distinguish between integers and floating-point numbers, while
19
+ * some don't. In json11, we choose the latter. Because some JSON implementations (namely
20
+ * Javascript itself) treat all numbers as the same type, distinguishing the two leads
21
+ * to JSON that will be *silently* changed by a round-trip through those implementations.
22
+ * Dangerous! To avoid that risk, json11 stores all numbers as double internally, but also
23
+ * provides integer helpers.
24
+ *
25
+ * Fortunately, double-precision IEEE754 ('double') can precisely store any integer in the
26
+ * range +/-2^53, which includes every 'int' on most systems. (Timestamps often use int64
27
+ * or long long to avoid the Y2038K problem; a double storing microseconds since some epoch
28
+ * will be exact for +/- 275 years.)
29
+ */
30
+
31
+/* Copyright (c) 2013 Dropbox, Inc.
32
+ *
33
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
34
+ * of this software and associated documentation files (the "Software"), to deal
35
+ * in the Software without restriction, including without limitation the rights
36
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
37
+ * copies of the Software, and to permit persons to whom the Software is
38
+ * furnished to do so, subject to the following conditions:
39
+ *
40
+ * The above copyright notice and this permission notice shall be included in
41
+ * all copies or substantial portions of the Software.
42
+ *
43
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
44
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
45
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
46
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
47
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
48
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
49
+ * THE SOFTWARE.
50
+ */
51
+
52
+#pragma once
53
+
54
+#include <string>
55
+#include <vector>
56
+#include <map>
57
+#include <memory>
58
+#include <initializer_list>
59
+
60
+#ifdef _MSC_VER
61
+    #if _MSC_VER <= 1800 // VS 2013
62
+        #ifndef noexcept
63
+            #define noexcept throw()
64
+        #endif
65
+
66
+        #ifndef snprintf
67
+            #define snprintf _snprintf_s
68
+        #endif
69
+    #endif
70
+#endif
71
+
72
+namespace json11 {
73
+
74
+enum JsonParse {
75
+    STANDARD, COMMENTS
76
+};
77
+
78
+class JsonValue;
79
+
80
+class Json  final{ //final
81
+public:
82
+    // Types
83
+    enum Type {
84
+        NUL, NUMBER, BOOL, STRING, ARRAY, OBJECT
85
+    };
86
+
87
+    // Array and object typedefs
88
+    typedef std::vector<Json> array;
89
+    typedef std::map<std::string, Json> object;
90
+
91
+    // Constructors for the various types of JSON value.
92
+    Json() noexcept;                // NUL
93
+    Json(std::nullptr_t) noexcept;  // NUL
94
+    Json(double value);             // NUMBER
95
+    Json(int value);                // NUMBER
96
+    Json(bool value);               // BOOL
97
+    Json(const std::string &value); // STRING
98
+    Json(std::string &&value);      // STRING
99
+    Json(const char * value);       // STRING
100
+    Json(const array &values);      // ARRAY
101
+    Json(array &&values);           // ARRAY
102
+    Json(const object &values);     // OBJECT
103
+    Json(object &&values);          // OBJECT
104
+    void add(std::string &key, std::string value);
105
+
106
+    // Implicit constructor: anything with a to_json() function.
107
+    template <class T, class = decltype(&T::to_json)>
108
+    Json(const T & t) : Json(t.to_json()) {}
109
+
110
+    // Implicit constructor: map-like objects (std::map, std::unordered_map, etc)
111
+    template <class M, typename std::enable_if<
112
+        std::is_constructible<std::string, typename M::key_type>::value
113
+        && std::is_constructible<Json, typename M::mapped_type>::value,
114
+            int>::type = 0>
115
+    Json(const M & m) : Json(object(m.begin(), m.end())) {}
116
+
117
+    // Implicit constructor: vector-like objects (std::list, std::vector, std::set, etc)
118
+    template <class V, typename std::enable_if<
119
+        std::is_constructible<Json, typename V::value_type>::value,
120
+            int>::type = 0>
121
+    Json(const V & v) : Json(array(v.begin(), v.end())) {}
122
+
123
+    // This prevents Json(some_pointer) from accidentally producing a bool. Use
124
+    // Json(bool(some_pointer)) if that behavior is desired.
125
+    Json(void *) = delete;
126
+
127
+    // Accessors
128
+    Type type() const;
129
+
130
+    bool is_null()   const { return type() == NUL; }
131
+    bool is_number() const { return type() == NUMBER; }
132
+    bool is_bool()   const { return type() == BOOL; }
133
+    bool is_string() const { return type() == STRING; }
134
+    bool is_array()  const { return type() == ARRAY; }
135
+    bool is_object() const { return type() == OBJECT; }
136
+
137
+
138
+    // Return the enclosed value if this is a number, 0 otherwise. Note that json11 does not
139
+    // distinguish between integer and non-integer numbers - number_value() and int_value()
140
+    // can both be applied to a NUMBER-typed object.
141
+    double number_value() const;
142
+    int int_value() const;
143
+
144
+    // Return the enclosed value if this is a boolean, false otherwise.
145
+    bool bool_value() const;
146
+    // Return the enclosed string if this is a string, "" otherwise.
147
+    const std::string &string_value() const;
148
+    // Return the enclosed std::vector if this is an array, or an empty vector otherwise.
149
+    const array &array_items() const;
150
+    // Return the enclosed std::map if this is an object, or an empty map otherwise.
151
+    const object &object_items() const;
152
+
153
+    // Return a reference to arr[i] if this is an array, Json() otherwise.
154
+    const Json & operator[](size_t i) const;
155
+    // Return a reference to obj[key] if this is an object, Json() otherwise.
156
+    const Json & operator[](const std::string &key) const;
157
+
158
+    // Serialize.
159
+    void dump(std::string &out) const;
160
+    std::string dump() const {
161
+        std::string out;
162
+        dump(out);
163
+        return out;
164
+    }
165
+
166
+    // Parse. If parse fails, return Json() and assign an error message to err.
167
+    static Json parse(const std::string & in,
168
+                      std::string & err,
169
+                      JsonParse strategy = JsonParse::STANDARD);
170
+    static Json parse(const char * in,
171
+                      std::string & err,
172
+                      JsonParse strategy = JsonParse::STANDARD) {
173
+        if (in) {
174
+            return parse(std::string(in), err, strategy);
175
+        } else {
176
+            err = "null input";
177
+            return nullptr;
178
+        }
179
+    }
180
+    // Parse multiple objects, concatenated or separated by whitespace
181
+    static std::vector<Json> parse_multi(
182
+        const std::string & in,
183
+        std::string::size_type & parser_stop_pos,
184
+        std::string & err,
185
+        JsonParse strategy = JsonParse::STANDARD);
186
+
187
+    static inline std::vector<Json> parse_multi(
188
+        const std::string & in,
189
+        std::string & err,
190
+        JsonParse strategy = JsonParse::STANDARD) {
191
+        std::string::size_type parser_stop_pos;
192
+        return parse_multi(in, parser_stop_pos, err, strategy);
193
+    }
194
+
195
+    bool operator== (const Json &rhs) const;
196
+    bool operator<  (const Json &rhs) const;
197
+    bool operator!= (const Json &rhs) const { return !(*this == rhs); }
198
+    bool operator<= (const Json &rhs) const { return !(rhs < *this); }
199
+    bool operator>  (const Json &rhs) const { return  (rhs < *this); }
200
+    bool operator>= (const Json &rhs) const { return !(*this < rhs); }
201
+
202
+    /* has_shape(types, err)
203
+     *
204
+     * Return true if this is a JSON object and, for each item in types, has a field of
205
+     * the given type. If not, return false and set err to a descriptive message.
206
+     */
207
+    typedef std::initializer_list<std::pair<std::string, Type>> shape;
208
+    bool has_shape(const shape & types, std::string & err) const;
209
+
210
+private:
211
+    std::shared_ptr<JsonValue> m_ptr;
212
+};
213
+
214
+// Internal class hierarchy - JsonValue objects are not exposed to users of this API.
215
+class JsonValue {
216
+protected:
217
+    friend class Json;
218
+    friend class JsonInt;
219
+    friend class JsonDouble;
220
+    virtual Json::Type type() const = 0;
221
+    virtual bool equals(const JsonValue * other) const = 0;
222
+    virtual bool less(const JsonValue * other) const = 0;
223
+    virtual void dump(std::string &out) const = 0;
224
+    virtual double number_value() const;
225
+    virtual int int_value() const;
226
+    virtual bool bool_value() const;
227
+    virtual const std::string &string_value() const;
228
+    virtual const Json::array &array_items() const;
229
+    virtual const Json &operator[](size_t i) const;
230
+    virtual const Json::object &object_items() const;
231
+    virtual const Json &operator[](const std::string &key) const;
232
+    virtual ~JsonValue() {}
233
+
234
+};
235
+
236
+} // namespace json11
237
x265_2.4.tar.gz/source/dynamicHDR10/metadataFromJson.cpp Added
580
 
1
@@ -0,0 +1,578 @@
2
+/**
3
+ * @file                       metadataFromJson.cpp
4
+ * @brief                      Reads a JSON file and produces a byte array containing the metadata to be embedded in different ways.
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+**/
26
+
27
+#include "metadataFromJson.h"
28
+
29
+#include <fstream>
30
+#include <iostream>
31
+#include <math.h>
32
+#include "sstream"
33
+#include "sys/stat.h"
34
+
35
+#include "BasicStructures.h"
36
+#include "SeiMetadataDictionary.h"
37
+
38
+#define M_PI 3.14159265358979323846
39
+
40
+using namespace SeiMetadataDictionary;
41
+
42
+class metadataFromJson::DynamicMetaIO
43
+{
44
+public:
45
+    DynamicMetaIO() :
46
+        mCurrentStreamBit(8),
47
+        mCurrentStreamByte(0)
48
+    {}
49
+
50
+    ~DynamicMetaIO(){}
51
+
52
+    int mCurrentStreamBit;
53
+    int mCurrentStreamByte;
54
+
55
+    bool luminanceParamFromJson(const Json &data, LuminanceParameters &obj)
56
+    {
57
+        JsonObject lumJsonData = data.object_items();
58
+        if(!lumJsonData.empty())
59
+        {
60
+            JsonObject percentileData = lumJsonData[PercentileNames::TagName].object_items();
61
+            obj.order = percentileData[PercentileNames::NumberOfPercentiles].int_value();
62
+
63
+            obj.averageLuminance = static_cast<float>(lumJsonData[LuminanceNames::AverageRGB].number_value());
64
+            obj.maxRLuminance = static_cast<float>(lumJsonData[LuminanceNames::MaxSCL0].number_value());
65
+            obj.maxGLuminance = static_cast<float>(lumJsonData[LuminanceNames::MaxSCL1].number_value());
66
+            obj.maxBLuminance = static_cast<float>(lumJsonData[LuminanceNames::MaxSCL2].number_value());
67
+
68
+            if(!percentileData.empty())
69
+            {
70
+                obj.percentiles.resize(obj.order);
71
+                for(int i = 0; i < obj.order; ++i)
72
+                {
73
+                    std::string percentileTag = PercentileNames::TagName;
74
+                    percentileTag += std::to_string(i);
75
+                    obj.percentiles[i] = static_cast<unsigned int>(percentileData[percentileTag].int_value());
76
+                }
77
+            }
78
+
79
+            return true;
80
+        }
81
+        return false;
82
+    }
83
+
84
+    bool percentagesFromJson(const Json &data, std::vector<unsigned int> &percentages)
85
+    {
86
+        JsonObject jsonData = data.object_items();
87
+        if(!jsonData.empty())
88
+        {
89
+            JsonObject percentileData = jsonData[PercentileNames::TagName].object_items();
90
+            int order = percentileData[PercentileNames::NumberOfPercentiles].int_value();
91
+
92
+            percentages.resize(order);
93
+            for(int i = 0; i < order; ++i)
94
+            {
95
+                std::string percentileTag = PercentileNames::PercentilePercentageValue[i];
96
+                percentages[i] = static_cast<unsigned int>(percentileData[percentileTag].int_value());
97
+            }
98
+
99
+            return true;
100
+        }
101
+        return false;
102
+    }
103
+
104
+    bool percentagesFromJson(const Json &data, unsigned int *percentages)
105
+    {
106
+        JsonObject jsonData = data.object_items();
107
+        if(!jsonData.empty())
108
+        {
109
+            JsonObject percentileData = jsonData[PercentileNames::TagName].object_items();
110
+            int order = percentileData[PercentileNames::NumberOfPercentiles].int_value();
111
+
112
+            for(int i = 0; i < order; ++i)
113
+            {
114
+                std::string percentileTag = PercentileNames::PercentilePercentageValue[i];
115
+                percentages[i] = static_cast<unsigned int>(percentileData[percentileTag].int_value());
116
+            }
117
+
118
+            return true;
119
+        }
120
+        return false;
121
+    }
122
+
123
+    bool bezierCurveFromJson(const Json &data, BezierCurveData &obj)
124
+    {
125
+        JsonObject jsonData = data.object_items();
126
+        if(!jsonData.empty())
127
+        {
128
+            obj.order = jsonData[BezierCurveNames::NumberOfAnchors].int_value();
129
+            obj.coeff.resize(obj.order);
130
+            obj.sPx = jsonData[BezierCurveNames::KneePointX].int_value();
131
+            obj.sPy = jsonData[BezierCurveNames::KneePointY].int_value();
132
+            for(int i = 0; i < obj.order; ++i)
133
+            {
134
+                obj.coeff[i] = jsonData[BezierCurveNames::Anchors[i]].int_value();
135
+            }
136
+
137
+            return true;
138
+        }
139
+        return false;
140
+    }
141
+
142
+    template<typename T>
143
+    void appendBits(uint8_t *dataStream, T data, int bitsToWrite)
144
+    {
145
+        //TODO: Check if bitsToWrite is <= sizeOf(T);
146
+        while (bitsToWrite > 0)
147
+        {
148
+            /* if all data to write fits inside the current byte */
149
+            if (bitsToWrite < mCurrentStreamBit )
150
+            {
151
+                int bitshift = mCurrentStreamBit - bitsToWrite;
152
+                dataStream[mCurrentStreamByte] += static_cast<uint8_t>(data << bitshift);
153
+                mCurrentStreamBit -= bitsToWrite;
154
+                bitsToWrite = 0;
155
+            }
156
+            /* if all data to write needs more than the current byte space */
157
+            else
158
+            {
159
+                int bitshift = bitsToWrite - mCurrentStreamBit;
160
+                dataStream[mCurrentStreamByte] += static_cast<uint8_t>(data >> bitshift);
161
+                bitsToWrite -= mCurrentStreamBit ;
162
+                mCurrentStreamBit = 8;
163
+                mCurrentStreamByte++;
164
+            }
165
+        }
166
+    }
167
+
168
+    void setPayloadSize(uint8_t *dataStream, int positionOnStream, int payload)
169
+    {
170
+        int payloadBytes = 1;
171
+
172
+        for(;payload > 0xFF; payload -= 0xFF, ++payloadBytes);
173
+
174
+        if(payloadBytes > 1)
175
+        {
176
+            shiftData(dataStream, payloadBytes-1, mCurrentStreamByte, positionOnStream);
177
+            mCurrentStreamByte += payloadBytes-1;
178
+
179
+            for(int i = 0; i < payloadBytes; ++i)
180
+            {
181
+                if(payloadBytes-1 == i)
182
+                {
183
+                    dataStream[positionOnStream++] = static_cast<uint8_t>(payload);
184
+                }
185
+                else
186
+                {
187
+                    dataStream[positionOnStream++] = 0xFF;
188
+                }
189
+            }
190
+        }
191
+        else
192
+        {
193
+            dataStream[positionOnStream] = static_cast<uint8_t>(payload);
194
+        }
195
+    }
196
+
197
+    void shiftData(uint8_t *dataStream, int shiftSize, int streamSize, int startPoint = 0)
198
+    {
199
+        for(int i = streamSize; i > startPoint; --i)
200
+        {
201
+            dataStream[i + shiftSize] = dataStream[i];
202
+        }
203
+    }
204
+
205
+//    const std::string LocalParameters = std::string("LocalParameters");
206
+//    const std::string TargetDisplayLuminance = std::string("TargetedSystemDisplayMaximumLuminance");
207
+};
208
+
209
+metadataFromJson::metadataFromJson() :
210
+    mPimpl(new DynamicMetaIO())
211
+{
212
+
213
+}
214
+
215
+metadataFromJson::~metadataFromJson()
216
+{
217
+    delete mPimpl;
218
+}
219
+
220
+
221
+bool metadataFromJson::frameMetadataFromJson(const char* filePath,
222
+                                              int frame,
223
+                                              uint8_t *&metadata)
224
+{
225
+    std::string path(filePath);
226
+    JsonArray fileData = JsonHelper::readJsonArray(path);
227
+
228
+    if(fileData.empty())
229
+    {
230
+        return false;
231
+    }
232
+
233
+//    frame = frame + 1; //index on the array start at 0 frames starts at 1
234
+    int numFrames = static_cast<int>(fileData.size());
235
+
236
+    if(frame >= numFrames)
237
+    {
238
+        return false;
239
+    }
240
+
241
+    int mSEIBytesToRead = 509;
242
+
243
+    if(metadata)
244
+    {
245
+        delete(metadata);
246
+    }
247
+    metadata = new uint8_t[mSEIBytesToRead];
248
+    mPimpl->mCurrentStreamBit = 8;
249
+    mPimpl->mCurrentStreamByte = 1;
250
+
251
+    for(int j = 0; j < mSEIBytesToRead; ++j)
252
+    {
253
+        (metadata)[j] = 0;
254
+    }
255
+
256
+    fillMetadataArray(fileData, frame, metadata);
257
+    mPimpl->setPayloadSize(metadata, 0, mPimpl->mCurrentStreamByte);
258
+    return true;
259
+}
260
+
261
+int metadataFromJson::movieMetadataFromJson(const char* filePath, uint8_t **&metadata)
262
+{
263
+    std::string path(filePath);
264
+    JsonArray fileData = JsonHelper::readJsonArray(path);
265
+    if (fileData.empty())
266
+    {
267
+        return -1;
268
+    }
269
+
270
+    int numFrames = static_cast<int>(fileData.size());
271
+    metadata = new uint8_t*[numFrames];
272
+    for (int frame = 0; frame < numFrames; ++frame)
273
+    {
274
+        metadata[frame] = new uint8_t[509];
275
+        for (int i = 0; i < 509; ++i)
276
+        {
277
+            metadata[frame][i] = 0;
278
+        }
279
+        mPimpl->mCurrentStreamBit = 8;
280
+        mPimpl->mCurrentStreamByte = 1;
281
+
282
+        fillMetadataArray(fileData, frame, metadata[frame]);
283
+
284
+        mPimpl->setPayloadSize(metadata[frame], 0, mPimpl->mCurrentStreamByte);
285
+
286
+    }
287
+
288
+    return numFrames;
289
+}
290
+
291
+bool metadataFromJson::extendedInfoFrameMetadataFromJson(const char* filePath,
292
+    int frame,
293
+    uint8_t *&metadata)
294
+{
295
+    std::string path(filePath);
296
+    JsonArray fileData = JsonHelper::readJsonArray(path);
297
+
298
+    if (fileData.empty())
299
+    {
300
+        return false;
301
+    }
302
+
303
+    int numFrames = static_cast<int>(fileData.size());
304
+    if (frame >= numFrames)
305
+    {
306
+        return false;
307
+    }
308
+
309
+    int mSEIBytesToRead = 509;
310
+
311
+    if (metadata)
312
+    {
313
+        delete(metadata);
314
+    }
315
+    metadata = new uint8_t[mSEIBytesToRead];
316
+    mPimpl->mCurrentStreamBit = 8;
317
+    mPimpl->mCurrentStreamByte = 0;
318
+
319
+    for (int j = 0; j < mSEIBytesToRead; ++j)
320
+    {
321
+        (metadata)[j] = 0;
322
+    }
323
+
324
+    const uint16_t extendedInfoframeType = 0x0004;
325
+    mPimpl->appendBits(metadata, extendedInfoframeType, 16);
326
+
327
+    /* NOTE: We leave TWO BYTES of space for the payload */
328
+    mPimpl->mCurrentStreamByte += 2;
329
+
330
+    fillMetadataArray(fileData, frame, metadata);
331
+
332
+    /* Set payload in bytes 2 & 3 as indicated in Extended InfoFrame Type syntax */
333
+    metadata[2] = (mPimpl->mCurrentStreamByte & 0xFF00) >> 8;
334
+    metadata[3] = (mPimpl->mCurrentStreamByte & 0x00FF);
335
+    return true;
336
+}
337
+
338
+int metadataFromJson::movieExtendedInfoFrameMetadataFromJson(const char* filePath, uint8_t **&metadata)
339
+{
340
+   std::string path(filePath);
341
+    JsonArray fileData = JsonHelper::readJsonArray(path);
342
+    if(fileData.empty())
343
+    {
344
+        return -1;
345
+    }
346
+
347
+    int numFrames = static_cast<int>(fileData.size());
348
+    metadata = new uint8_t*[numFrames];
349
+    for(int frame = 0; frame < numFrames; ++frame)
350
+    {
351
+        metadata[frame] = new uint8_t[509];
352
+        for(int i = 0; i < 509; ++i) 
353
+       {
354
+           metadata[frame][i] = 0;
355
+       }
356
+        mPimpl->mCurrentStreamBit = 8;
357
+        mPimpl->mCurrentStreamByte = 0;
358
+
359
+        const uint16_t extendedInfoframeType = 0x0004;
360
+        mPimpl->appendBits(metadata[frame], extendedInfoframeType, 16);
361
+
362
+        /* NOTE: We leave TWO BYTES of space for the payload */
363
+        mPimpl->mCurrentStreamByte += 2;
364
+
365
+        fillMetadataArray(fileData, frame, metadata[frame]);
366
+
367
+        /* Set payload in bytes 2 & 3 as indicated in Extended InfoFrame Type syntax */
368
+        metadata[frame][2] = (mPimpl->mCurrentStreamByte & 0xFF00) >> 8;
369
+        metadata[frame][3] = (mPimpl->mCurrentStreamByte & 0x00FF);
370
+    }
371
+
372
+    return numFrames;
373
+}
374
+
375
+void metadataFromJson::fillMetadataArray(const JsonArray &fileData, int frame, uint8_t *&metadata)
376
+{
377
+    const uint8_t countryCode = 0xB5;
378
+    const uint16_t terminalProviderCode = 0x003C;
379
+    const uint16_t terminalProviderOrientedCode = 0x0001;
380
+    const uint8_t applicationIdentifier = 4;
381
+    const uint8_t applicationVersion = 0;
382
+
383
+    mPimpl->appendBits(metadata, countryCode, 8);
384
+    mPimpl->appendBits(metadata, terminalProviderCode, 16);
385
+    mPimpl->appendBits(metadata, terminalProviderOrientedCode, 16);
386
+
387
+    mPimpl->appendBits(metadata, applicationIdentifier, 8);
388
+    mPimpl->appendBits(metadata, applicationVersion, 8);
389
+
390
+    //Note: Validated only add up to two local selections, ignore the rest
391
+    JsonArray jsonArray = fileData[frame][JsonDataKeys::LocalParameters].array_items();
392
+    int ellipsesNum = static_cast<int>(jsonArray.size() > 2 ? 2 : jsonArray.size());
393
+
394
+    uint16_t numWindows = 1 + static_cast<uint16_t>(ellipsesNum);
395
+
396
+    mPimpl->appendBits(metadata, numWindows, 2);
397
+    for (int i = 0; i < ellipsesNum; ++i)
398
+    {
399
+        mPimpl->appendBits(metadata, jsonArray[i][EllipseSelectionNames::WindowData]
400
+            [EllipseSelectionNames::WindowUpperLeftCornerX].int_value(), 16);
401
+        mPimpl->appendBits(metadata, jsonArray[i][EllipseSelectionNames::WindowData]
402
+            [EllipseSelectionNames::WindowUpperLeftCornerY].int_value(), 16);
403
+        mPimpl->appendBits(metadata, jsonArray[i][EllipseSelectionNames::WindowData]
404
+            [EllipseSelectionNames::WindowLowerRightCornerX].int_value(), 16);
405
+        mPimpl->appendBits(metadata, jsonArray[i][EllipseSelectionNames::WindowData]
406
+            [EllipseSelectionNames::WindowLowerRightCornerY].int_value(), 16);
407
+
408
+        JsonObject ellipseJsonObject = jsonArray[i][EllipseNames::TagName].object_items();
409
+
410
+        mPimpl->appendBits(metadata,
411
+            static_cast<uint16_t>(ellipseJsonObject[EllipseNames::CenterOfEllipseX].int_value()),
412
+            16);
413
+
414
+        mPimpl->appendBits(metadata,
415
+            static_cast<uint16_t>(ellipseJsonObject[EllipseNames::CenterOfEllipseY].int_value()),
416
+            16);
417
+
418
+        int angle = ellipseJsonObject[EllipseNames::RotationAngle].int_value();
419
+        uint8_t rotationAngle = static_cast<uint8_t>((angle > 180.0) ? angle - 180.0 : angle);
420
+        mPimpl->appendBits(metadata, rotationAngle, 8);
421
+
422
+        uint16_t semimajorExternalAxis =
423
+            static_cast<uint16_t>(ellipseJsonObject[EllipseNames::SemiMajorAxisExternalEllipse].int_value());
424
+
425
+        uint16_t semiminorExternalAxis =
426
+            static_cast<uint16_t>(ellipseJsonObject[EllipseNames::SemiMinorAxisExternalEllipse].int_value());
427
+
428
+        uint16_t semimajorInternalEllipse =
429
+            static_cast<uint16_t>(ellipseJsonObject[EllipseNames::SemiMajorAxisInternalEllipse].int_value());
430
+
431
+        mPimpl->appendBits(metadata, semimajorInternalEllipse, 16);
432
+
433
+        mPimpl->appendBits(metadata, semimajorExternalAxis, 16);
434
+        mPimpl->appendBits(metadata, semiminorExternalAxis, 16);
435
+        /*bool*/ uint8_t overlapProcessOption = static_cast<uint8_t>(ellipseJsonObject[EllipseNames::OverlapProcessOption].int_value()); //1; 
436
+        //TODO: Uses Layering method, the value is "1"
437
+        mPimpl->appendBits(metadata, overlapProcessOption, 1);
438
+    }
439
+    /* Targeted System Display Data */
440
+    uint32_t TEMPmonitorPeak = fileData[frame][JsonDataKeys::TargetDisplayLuminance].int_value();     //500;
441
+    mPimpl->appendBits(metadata, TEMPmonitorPeak, 27);
442
+
443
+    //NOTE: Set as false for now, as requested
444
+    /*bool*/uint8_t targetedSystemDisplayActualPeakLuminanceFlag = 0; /*false*/
445
+    mPimpl->appendBits(metadata, targetedSystemDisplayActualPeakLuminanceFlag, 1);
446
+    if (targetedSystemDisplayActualPeakLuminanceFlag)
447
+    {
448
+        //TODO
449
+    }
450
+
451
+    /* Max rgb values (maxScl)*/
452
+    /* Luminance values/percentile for each window */
453
+    for (int w = 0; w < numWindows; ++w)
454
+    {
455
+        Json lumObj = fileData[frame][LuminanceNames::TagName];
456
+        LuminanceParameters luminanceData;
457
+        if (!mPimpl->luminanceParamFromJson(lumObj, luminanceData))
458
+        {
459
+            std::cout << "error parsing luminance parameters frame: " << w << std::endl;
460
+        }
461
+
462
+        /* NOTE: Maxscl from 0 t 100,000 based on data that says in values of 0.00001
463
+        * one for each channel R,G,B
464
+        */
465
+
466
+        mPimpl->appendBits(metadata, static_cast<uint8_t>(((int)luminanceData.maxRLuminance & 0x10000) >> 16), 1);
467
+        mPimpl->appendBits(metadata, static_cast<uint16_t>((int)luminanceData.maxRLuminance & 0xFFFF), 16);
468
+        mPimpl->appendBits(metadata, static_cast<uint8_t>(((int)luminanceData.maxGLuminance & 0x10000) >> 16), 1);
469
+        mPimpl->appendBits(metadata, static_cast<uint16_t>((int)luminanceData.maxGLuminance & 0xFFFF), 16);
470
+        mPimpl->appendBits(metadata, static_cast<uint8_t>(((int)luminanceData.maxBLuminance & 0x10000) >> 16), 1);
471
+        mPimpl->appendBits(metadata, static_cast<uint16_t>((int)luminanceData.maxBLuminance & 0xFFFF), 16);
472
+        /* changed from maxRGBLuminance to average luminance to match stms implementation */
473
+        mPimpl->appendBits(metadata, static_cast<uint8_t>(((int)luminanceData.averageLuminance & 0x10000) >> 16), 1);
474
+        mPimpl->appendBits(metadata, static_cast<uint16_t>((int)luminanceData.averageLuminance & 0xFFFF), 16);
475
+
476
+        /* Percentiles */
477
+        uint8_t numDistributionMaxrgbPercentiles = static_cast<uint8_t>(luminanceData.order);
478
+        mPimpl->appendBits(metadata, numDistributionMaxrgbPercentiles, 4);
479
+
480
+        std::vector<unsigned int>percentilPercentages;
481
+        mPimpl->percentagesFromJson(lumObj, percentilPercentages);
482
+        for (int i = 0; i < numDistributionMaxrgbPercentiles; ++i)
483
+        {
484
+            uint8_t distributionMaxrgbPercentage = static_cast<uint8_t>(percentilPercentages.at(i));
485
+            mPimpl->appendBits(metadata, distributionMaxrgbPercentage, 7);
486
+
487
+            // 17bits: 1bit then 16
488
+            unsigned int ithPercentile = luminanceData.percentiles.at(i);
489
+            uint8_t highValue = static_cast<uint8_t>((ithPercentile & 0x10000) >> 16);
490
+            uint16_t lowValue = static_cast<uint16_t>(ithPercentile & 0xFFFF);
491
+            mPimpl->appendBits(metadata, highValue, 1);
492
+            mPimpl->appendBits(metadata, lowValue, 16);
493
+        }
494
+
495
+        /* 10bits: Fraction bright pixels */
496
+        uint16_t fractionBrightPixels = 1;
497
+        mPimpl->appendBits(metadata, fractionBrightPixels, 10);
498
+
499
+    }
500
+
501
+    /* Note: Set to false by now as requested  */
502
+    uint8_t masteringDisplayActualPeakLuminanceFlag = 0;
503
+    mPimpl->appendBits(metadata, masteringDisplayActualPeakLuminanceFlag, 1);
504
+    if (masteringDisplayActualPeakLuminanceFlag)
505
+    {
506
+        //TODO
507
+    }
508
+    // BEZIER CURVE DATA
509
+    for (int w = 0; w < numWindows; ++w)
510
+    {
511
+        //TODO: 
512
+        uint8_t toneMappingFlag = 1;
513
+        mPimpl->appendBits(metadata, toneMappingFlag, 1);
514
+        if (toneMappingFlag)
515
+        {
516
+            Json bezierData = fileData[frame][BezierCurveNames::TagName];
517
+            BezierCurveData curveData;
518
+
519
+            /* Select curve data based on global window or local window */
520
+            if (w == 0)
521
+            {
522
+                if (!mPimpl->bezierCurveFromJson(bezierData, curveData))
523
+                {
524
+                    std::cout << "error parsing bezierCurve frame: " << w << std::endl;
525
+                }
526
+            }
527
+            else
528
+            {
529
+                if (!mPimpl->bezierCurveFromJson(jsonArray[w - 1][BezierCurveNames::TagName], curveData))
530
+                {
531
+                    std::cout << "error parsing bezierCurve ellipse: " << w - 1 << std::endl;
532
+                }
533
+            }
534
+
535
+            uint16_t kneePointX = static_cast<uint16_t>(curveData.sPx);
536
+            mPimpl->appendBits(metadata, kneePointX, 12);
537
+            uint16_t kneePointY = static_cast<uint16_t>(curveData.sPy);
538
+            mPimpl->appendBits(metadata, kneePointY, 12);
539
+
540
+            uint8_t numBezierCurveAnchors = static_cast<uint8_t>(curveData.order);// - 1;
541
+            mPimpl->appendBits(metadata, numBezierCurveAnchors, 4);
542
+
543
+            /* Curve anchors 10bits */
544
+            for (int i = 0; i < numBezierCurveAnchors; ++i)
545
+            {
546
+                uint16_t anchor = static_cast<uint16_t>(curveData.coeff.at(i));
547
+                mPimpl->appendBits(metadata, anchor, 10);
548
+            }
549
+        }
550
+    }
551
+    /* Set to false as requested */
552
+    bool colorSaturationMappingFlag = 0;
553
+    mPimpl->appendBits(metadata, colorSaturationMappingFlag, 1);
554
+    if (colorSaturationMappingFlag)
555
+    {
556
+        //TODO
557
+    }
558
+
559
+    if (mPimpl->mCurrentStreamBit == 8)
560
+    {
561
+        mPimpl->mCurrentStreamByte -= 1;
562
+    }
563
+}
564
+
565
+void metadataFromJson::clear(uint8_t **&metadata, const int numberOfFrames)
566
+{
567
+    if (metadata && numberOfFrames > 0)
568
+    {
569
+        for (int i = 0; i < numberOfFrames; ++i)
570
+        {
571
+            if (metadata[i])
572
+            {
573
+                delete[] metadata[i];
574
+            }
575
+        }
576
+        delete[] metadata;
577
+        metadata = NULL;
578
+    }
579
+}
580
x265_2.4.tar.gz/source/dynamicHDR10/metadataFromJson.h Added
108
 
1
@@ -0,0 +1,106 @@
2
+/**
3
+ * @file                       metadataFromJson.h
4
+ * @brief                      Reads a JSON file and produces a byte array containing the metadata to be embedded for a frame.
5
+ * @author                     Daniel Maximiliano Valenzuela, Seongnam Oh.
6
+ * @create date                03/01/2017
7
+ * @version                    0.0.1
8
+ *
9
+ * Copyright @ 2017 Samsung Electronics, DMS Lab, Samsung Research America and Samsung Research Tijuana
10
+ *
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; either version 2
14
+ * of the License, or (at your option) any later version.
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
24
+ * MA 02110-1301, USA.
25
+
26
+**/
27
+
28
+#ifndef METADATAFROMJSON_H
29
+#define METADATAFROMJSON_H
30
+
31
+#include<stdint.h>
32
+#include "string"
33
+#include "JsonHelper.h"
34
+
35
+class metadataFromJson
36
+{
37
+
38
+public:
39
+    metadataFromJson();
40
+    ~metadataFromJson();
41
+
42
+
43
+    /**
44
+     * @brief frameMetadataFromJson: Generates a sigle frame metadata array from Json file with all
45
+     *          metadata information from movie.
46
+     * @param filePath: path to Json file containing movie metadata information.
47
+     * @param frame: frame Id number in respect to the movie.
48
+     * @param metadata (output): receives an empty pointer that will be set to point to metadata
49
+     *          array. Note: if pointer is set it will be deleted.
50
+     * @return True if succesful
51
+     */
52
+    bool frameMetadataFromJson(const char* filePath,
53
+                                int frame,
54
+                                uint8_t *&metadata);
55
+   
56
+    /**
57
+     * @brief movieMetadataFromJson: Generates metadata array from Json file with all metadata
58
+     *          information from movie.
59
+     * @param filePath: path to Json file containing movie metadata information.
60
+     * @param metadata (output): receives an empty pointer that will be set to point to metadata
61
+     *          array. Note: if pointer is set it will be deleted.
62
+     * @return int: number of frames in the movie, -1 if the process fails to obtain the metadata.
63
+     */
64
+    int movieMetadataFromJson(const char* filePath,
65
+                                uint8_t **&metadata);
66
+
67
+    /**
68
+    * @brief extendedInfoFrameMetadataFromJson: Generates Extended InfoFrame metadata array from Json file
69
+    *           with all metadata information from movie.
70
+    * @param filePath: path to Json file containing movie metadata information.
71
+    * @param metadata (output): receives an empty pointer that will be set to point to metadata
72
+    *          array. Note: if pointer is set it will be deleted.
73
+    * @return int: number of frames in the movie, -1 if the process fails to obtain the metadata.
74
+    */
75
+    bool extendedInfoFrameMetadataFromJson(const char* filePath,
76
+                                            int frame,
77
+                                            uint8_t *&metadata);
78
+
79
+    /**
80
+    * @brief movieMetadataFromJson: Generates Extended InfoFrame metadata array from Json file with all metadata
81
+    *          information from movie.
82
+    * @param filePath: path to Json file containing movie Extended InfoFrame metadata information.
83
+    * @param metadata (output): receives an empty pointer that will be set to point to metadata
84
+    *          array. Note: if pointer is set it will be deleted.
85
+    * @return int: number of frames in the movie, -1 if the process fails to obtain the metadata.
86
+    */
87
+    int movieExtendedInfoFrameMetadataFromJson(const char* filePath,
88
+        uint8_t **&metadata);
89
+
90
+    /**
91
+
92
+    * @brief clear: Clears the memory of the given array and size.
93
+    * @param metadata: metadata array to be cleared.
94
+    * @param numberOfFrames: number of frames in the metadata array.
95
+    * @return
96
+    */
97
+    void clear(uint8_t **&metadata,
98
+                const int numberOfFrames);
99
+
100
+private:
101
+
102
+    class DynamicMetaIO;
103
+    DynamicMetaIO *mPimpl;
104
+    void fillMetadataArray(const JsonArray &fileData, int frame, uint8_t *&metadata);
105
+};
106
+
107
+#endif // METADATAFROMJSON_H
108
x265_2.3.tar.gz/source/encoder/analysis.cpp -> x265_2.4.tar.gz/source/encoder/analysis.cpp Changed
234
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
 *          Steve Borho <steve@borho.org>
8
@@ -167,15 +167,18 @@
9
         }
10
     }
11
 
12
-    if (m_param->analysisMode && m_slice->m_sliceType != I_SLICE)
13
+    if (m_param->analysisMode && m_slice->m_sliceType != I_SLICE && m_param->analysisRefineLevel > 1 && m_param->analysisRefineLevel < 10)
14
     {
15
         int numPredDir = m_slice->isInterP() ? 1 : 2;
16
         m_reuseInterDataCTU = (analysis_inter_data*)m_frame->m_analysisData.interData;
17
         m_reuseRef = &m_reuseInterDataCTU->ref[ctu.m_cuAddr * X265_MAX_PRED_MODE_PER_CTU * numPredDir];
18
         m_reuseDepth = &m_reuseInterDataCTU->depth[ctu.m_cuAddr * ctu.m_numPartitions];
19
         m_reuseModes = &m_reuseInterDataCTU->modes[ctu.m_cuAddr * ctu.m_numPartitions];
20
-        m_reusePartSize = &m_reuseInterDataCTU->partSize[ctu.m_cuAddr * ctu.m_numPartitions];
21
-        m_reuseMergeFlag = &m_reuseInterDataCTU->mergeFlag[ctu.m_cuAddr * ctu.m_numPartitions];
22
+        if (m_param->analysisRefineLevel > 4)
23
+        {
24
+            m_reusePartSize = &m_reuseInterDataCTU->partSize[ctu.m_cuAddr * ctu.m_numPartitions];
25
+            m_reuseMergeFlag = &m_reuseInterDataCTU->mergeFlag[ctu.m_cuAddr * ctu.m_numPartitions];
26
+        }
27
         if (m_param->analysisMode == X265_ANALYSIS_SAVE)
28
             for (int i = 0; i < X265_MAX_PRED_MODE_PER_CTU * numPredDir; i++)
29
                 m_reuseRef[i] = -1;
30
@@ -185,7 +188,7 @@
31
     if (m_slice->m_sliceType == I_SLICE)
32
     {
33
         analysis_intra_data* intraDataCTU = (analysis_intra_data*)m_frame->m_analysisData.intraData;
34
-        if (m_param->analysisMode == X265_ANALYSIS_LOAD)
35
+        if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_param->analysisRefineLevel > 1)
36
         {
37
             memcpy(ctu.m_cuDepth, &intraDataCTU->depth[ctu.m_cuAddr * numPartition], sizeof(uint8_t) * numPartition);
38
             memcpy(ctu.m_lumaIntraDir, &intraDataCTU->modes[ctu.m_cuAddr * numPartition], sizeof(uint8_t) * numPartition);
39
@@ -211,6 +214,26 @@
40
             /* generate residual for entire CTU at once and copy to reconPic */
41
             encodeResidue(ctu, cuGeom);
42
         }
43
+        else if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_param->analysisRefineLevel == 10)
44
+        {
45
+            analysis_inter_data* interDataCTU = (analysis_inter_data*)m_frame->m_analysisData.interData;
46
+            int posCTU = ctu.m_cuAddr * numPartition;
47
+            memcpy(ctu.m_cuDepth, &interDataCTU->depth[posCTU], sizeof(uint8_t) * numPartition);
48
+            memcpy(ctu.m_predMode, &interDataCTU->modes[posCTU], sizeof(uint8_t) * numPartition);
49
+            memcpy(ctu.m_partSize, &interDataCTU->partSize[posCTU], sizeof(uint8_t) * numPartition);
50
+            if (m_slice->m_sliceType == P_SLICE || m_param->bIntraInBFrames)
51
+            {
52
+                analysis_intra_data* intraDataCTU = (analysis_intra_data*)m_frame->m_analysisData.intraData;
53
+                memcpy(ctu.m_lumaIntraDir, &intraDataCTU->modes[posCTU], sizeof(uint8_t) * numPartition);
54
+                memcpy(ctu.m_chromaIntraDir, &intraDataCTU->chromaModes[posCTU], sizeof(uint8_t) * numPartition);
55
+            }
56
+            //Calculate log2CUSize from depth
57
+            for (uint32_t i = 0; i < cuGeom.numPartitions; i++)
58
+                ctu.m_log2CUSize[i] = (uint8_t)g_maxLog2CUSize - ctu.m_cuDepth[i];
59
+
60
+            qprdRefine (ctu, cuGeom, qp, qp);
61
+            return *m_modeDepth[0].bestMode;
62
+        }
63
         else if (m_param->bDistributeModeAnalysis && m_param->rdLevel >= 2)
64
             compressInterCU_dist(ctu, cuGeom, qp);
65
         else if (m_param->rdLevel <= 4)
66
@@ -313,6 +336,8 @@
67
     int lambdaQP = lqp;
68
 
69
     bool doQPRefine = (bDecidedDepth && depth <= m_slice->m_pps->maxCuDQPDepth) || (!bDecidedDepth && depth == m_slice->m_pps->maxCuDQPDepth);
70
+    if (m_param->analysisRefineLevel == 10)
71
+        doQPRefine = false;
72
 
73
     if (doQPRefine)
74
     {
75
@@ -1015,7 +1040,7 @@
76
         md.pred[PRED_2Nx2N].sa8dCost = 0;
77
     }
78
 
79
-    if (m_param->analysisMode == X265_ANALYSIS_LOAD)
80
+    if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_param->analysisRefineLevel > 1)
81
     {
82
         if (mightNotSplit && depth == m_reuseDepth[cuGeom.absPartIdx])
83
         {
84
@@ -1029,7 +1054,7 @@
85
                 if (m_param->rdLevel)
86
                     skipModes = m_param->bEnableEarlySkip && md.bestMode;
87
             }
88
-            if (m_reusePartSize[cuGeom.absPartIdx] == SIZE_2Nx2N)
89
+            if (m_param->analysisRefineLevel > 4 && m_reusePartSize[cuGeom.absPartIdx] == SIZE_2Nx2N)
90
             {
91
                 if (m_reuseModes[cuGeom.absPartIdx] != MODE_INTRA  && m_reuseModes[cuGeom.absPartIdx] != 4)
92
                 {
93
@@ -1582,7 +1607,7 @@
94
     splitData[3].initSplitCUData();
95
     uint32_t allSplitRefs = splitData[0].splitRefs | splitData[1].splitRefs | splitData[2].splitRefs | splitData[3].splitRefs;
96
     uint32_t refMasks[2];
97
-    if (m_param->analysisMode == X265_ANALYSIS_LOAD)
98
+    if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_param->analysisRefineLevel > 1)
99
     {
100
         if (mightNotSplit && depth == m_reuseDepth[cuGeom.absPartIdx])
101
         {
102
@@ -1600,7 +1625,7 @@
103
                 if (m_param->bEnableRecursionSkip && depth && m_modeDepth[depth - 1].bestMode)
104
                     skipRecursion = md.bestMode && !md.bestMode->cu.getQtRootCbf(0);
105
             }
106
-            if (m_reusePartSize[cuGeom.absPartIdx] == SIZE_2Nx2N)
107
+            if (m_param->analysisRefineLevel > 4 && m_reusePartSize[cuGeom.absPartIdx] == SIZE_2Nx2N)
108
                 skipRectAmp = true && !!md.bestMode;
109
         }
110
     }
111
@@ -2004,10 +2029,39 @@
112
         else
113
         {
114
             mode.cu.copyFromPic(parentCTU, cuGeom, m_csp, false);
115
-            for (int part = 0; part < (int)parentCTU.getNumPartInter(cuGeom.absPartIdx); part++)
116
+            uint32_t numPU = parentCTU.getNumPartInter(cuGeom.absPartIdx);
117
+            for (uint32_t part = 0; part < numPU; part++)
118
             {
119
                 PredictionUnit pu(mode.cu, cuGeom, part);
120
-                motionCompensation(mode.cu, pu, mode.predYuv, true, true);
121
+                if (m_param->analysisRefineLevel == 10)
122
+                {
123
+                    analysis_inter_data* interDataCTU = (analysis_inter_data*)m_frame->m_analysisData.interData;
124
+                    int cuIdx = (mode.cu.m_cuAddr * parentCTU.m_numPartitions) + cuGeom.absPartIdx;
125
+                    mode.cu.m_mergeFlag[pu.puAbsPartIdx] = interDataCTU->mergeFlag[cuIdx + part];
126
+                    mode.cu.setPUInterDir(interDataCTU->interDir[cuIdx + part], pu.puAbsPartIdx, part);
127
+                    for (int dir = 0; dir < m_slice->isInterB() + 1; dir++)
128
+                    {
129
+                        mode.cu.setPUMv(dir, interDataCTU->mv[dir][cuIdx + part], pu.puAbsPartIdx, part);
130
+                        mode.cu.setPURefIdx(dir, interDataCTU->refIdx[dir][cuIdx + part], pu.puAbsPartIdx, part);
131
+                        mode.cu.m_mvpIdx[dir][pu.puAbsPartIdx] = interDataCTU->mvpIdx[dir][cuIdx + part];
132
+                    }
133
+                    if (!mode.cu.m_mergeFlag[pu.puAbsPartIdx])
134
+                    {
135
+                        //AMVP
136
+                        MV mvc[(MD_ABOVE_LEFT + 1) * 2 + 2];
137
+                        mode.cu.getNeighbourMV(part, pu.puAbsPartIdx, mode.interNeighbours);
138
+                        for (int list = 0; list < m_slice->isInterB() + 1; list++)
139
+                        {
140
+                            int ref = mode.cu.m_refIdx[list][pu.puAbsPartIdx];
141
+                            if (ref == -1)
142
+                                continue;
143
+                            mode.cu.getPMV(mode.interNeighbours, list, ref, mode.amvpCand[list][ref], mvc);
144
+                            MV mvp = mode.amvpCand[list][ref][mode.cu.m_mvpIdx[list][pu.puAbsPartIdx]];
145
+                            mode.cu.m_mvd[list][pu.puAbsPartIdx] = mode.cu.m_mv[list][pu.puAbsPartIdx] - mvp;
146
+                        }
147
+                    }
148
+                }
149
+                motionCompensation(mode.cu, pu, mode.predYuv, true, (m_csp != X265_CSP_I400 && m_frame->m_fencPic->m_picCsp != X265_CSP_I400));
150
             }
151
 
152
             if (parentCTU.isSkipped(cuGeom.absPartIdx))
153
@@ -2016,7 +2070,7 @@
154
                 encodeResAndCalcRdInterCU(mode, cuGeom);
155
 
156
             /* checkMerge2Nx2N function performs checkDQP after encoding residual, do the same */
157
-            bool mergeInter2Nx2N = size == SIZE_2Nx2N && parentCTU.m_mergeFlag[cuGeom.absPartIdx];
158
+            bool mergeInter2Nx2N = size == SIZE_2Nx2N && mode.cu.m_mergeFlag[0];
159
             if (parentCTU.isSkipped(cuGeom.absPartIdx) || mergeInter2Nx2N)
160
                 checkDQP(mode, cuGeom);
161
         }
162
@@ -2026,6 +2080,9 @@
163
 
164
         if (mightSplit)
165
             addSplitFlagCost(*md.bestMode, cuGeom.depth);
166
+
167
+        if (mightSplit && m_param->rdLevel < 5)
168
+            checkDQPForSplitPred(*md.bestMode, cuGeom);
169
     }
170
     else
171
     {
172
@@ -2052,7 +2109,8 @@
173
                 if (m_slice->m_pps->bUseDQP && nextDepth <= m_slice->m_pps->maxCuDQPDepth)
174
                     nextQP = setLambdaFromQP(parentCTU, calculateQpforCuSize(parentCTU, childGeom));
175
 
176
-                qprdRefine(parentCTU, childGeom, nextQP, lqp);
177
+                int lamdaQP = m_param->analysisRefineLevel == 10 ? nextQP : lqp;
178
+                qprdRefine(parentCTU, childGeom, nextQP, lamdaQP);
179
 
180
                 // Save best CU and pred data for this sub CU
181
                 splitCU->copyPartFrom(nd.bestMode->cu, childGeom, subPartIdx);
182
@@ -2362,7 +2420,7 @@
183
     interMode.cu.setPredModeSubParts(MODE_INTER);
184
     int numPredDir = m_slice->isInterP() ? 1 : 2;
185
 
186
-    if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_reuseInterDataCTU)
187
+    if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_reuseInterDataCTU && m_param->analysisRefineLevel > 1)
188
     {
189
         int refOffset = cuGeom.geomRecurId * 16 * numPredDir + partSize * numPredDir * 2;
190
         int index = 0;
191
@@ -2404,7 +2462,7 @@
192
     }
193
     interMode.sa8dCost = m_rdCost.calcRdSADCost((uint32_t)interMode.distortion, interMode.sa8dBits);
194
 
195
-    if (m_param->analysisMode == X265_ANALYSIS_SAVE && m_reuseInterDataCTU)
196
+    if (m_param->analysisMode == X265_ANALYSIS_SAVE && m_reuseInterDataCTU && m_param->analysisRefineLevel > 1)
197
     {
198
         int refOffset = cuGeom.geomRecurId * 16 * numPredDir + partSize * numPredDir * 2;
199
         int index = 0;
200
@@ -2426,7 +2484,7 @@
201
     interMode.cu.setPredModeSubParts(MODE_INTER);
202
     int numPredDir = m_slice->isInterP() ? 1 : 2;
203
 
204
-    if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_reuseInterDataCTU)
205
+    if (m_param->analysisMode == X265_ANALYSIS_LOAD && m_reuseInterDataCTU && m_param->analysisRefineLevel > 1)
206
     {
207
         int refOffset = cuGeom.geomRecurId * 16 * numPredDir + partSize * numPredDir * 2;
208
         int index = 0;
209
@@ -2460,7 +2518,7 @@
210
     /* predInterSearch sets interMode.sa8dBits, but this is ignored */
211
     encodeResAndCalcRdInterCU(interMode, cuGeom);
212
 
213
-    if (m_param->analysisMode == X265_ANALYSIS_SAVE && m_reuseInterDataCTU)
214
+    if (m_param->analysisMode == X265_ANALYSIS_SAVE && m_reuseInterDataCTU && m_param->analysisRefineLevel > 1)
215
     {
216
         int refOffset = cuGeom.geomRecurId * 16 * numPredDir + partSize * numPredDir * 2;
217
         int index = 0;
218
@@ -2884,6 +2942,15 @@
219
 {
220
     FrameData& curEncData = *m_frame->m_encData;
221
     double qp = baseQp >= 0 ? baseQp : curEncData.m_cuStat[ctu.m_cuAddr].baseQp;
222
+
223
+    if (m_param->analysisMultiPassDistortion && m_param->rc.bStatRead)
224
+    {
225
+        m_multipassAnalysis = (analysis2PassFrameData*)m_frame->m_analysis2Pass.analysisFramedata;
226
+        if ((m_multipassAnalysis->threshold[ctu.m_cuAddr] < 0.9 || m_multipassAnalysis->threshold[ctu.m_cuAddr] > 1.1)
227
+            && m_multipassAnalysis->highDistortionCtuCount && m_multipassAnalysis->lowDistortionCtuCount)
228
+            qp += m_multipassAnalysis->offset[ctu.m_cuAddr];
229
+    }
230
+
231
     int loopIncr;
232
     if (m_param->rc.qgSize == 8)
233
         loopIncr = 8;
234
x265_2.3.tar.gz/source/encoder/analysis.h -> x265_2.4.tar.gz/source/encoder/analysis.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Deepthi Nandakumar <deepthi@multicorewareinc.com>
7
 *          Steve Borho <steve@borho.org>
8
x265_2.3.tar.gz/source/encoder/api.cpp -> x265_2.4.tar.gz/source/encoder/api.cpp Changed
49
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
@@ -171,7 +171,7 @@
9
 
10
     x265_param save;
11
     Encoder* encoder = static_cast<Encoder*>(enc);
12
-    if (encoder->m_reconfigure) /* Reconfigure in progress */
13
+    if (encoder->m_reconfigure || encoder->m_reconfigureRc) /* Reconfigure in progress */
14
         return 1;
15
     memcpy(&save, encoder->m_latestParam, sizeof(x265_param));
16
     int ret = encoder->reconfigureParam(encoder->m_latestParam, param_in);
17
@@ -197,7 +197,22 @@
18
                 return -1;
19
             }
20
         }
21
-        encoder->m_reconfigure = true;
22
+        if (encoder->m_reconfigureRc)
23
+        {
24
+            VPS saveVPS;
25
+            memcpy(&saveVPS.ptl, &encoder->m_vps.ptl, sizeof(saveVPS.ptl));
26
+            determineLevel(*encoder->m_latestParam, encoder->m_vps);
27
+            if (saveVPS.ptl.profileIdc != encoder->m_vps.ptl.profileIdc || saveVPS.ptl.levelIdc != encoder->m_vps.ptl.levelIdc
28
+                || saveVPS.ptl.tierFlag != encoder->m_vps.ptl.tierFlag)
29
+            {
30
+                x265_log(encoder->m_param, X265_LOG_WARNING, "Profile/Level/Tier has changed from %d/%d/%s to %d/%d/%s.Cannot reconfigure rate-control.\n",
31
+                         saveVPS.ptl.profileIdc, saveVPS.ptl.levelIdc, saveVPS.ptl.tierFlag ? "High" : "Main", encoder->m_vps.ptl.profileIdc,
32
+                         encoder->m_vps.ptl.levelIdc, encoder->m_vps.ptl.tierFlag ? "High" : "Main");
33
+                encoder->m_reconfigureRc = false;
34
+            }
35
+        }
36
+        else
37
+            encoder->m_reconfigure = true;
38
         encoder->printReconfigureParams();
39
     }
40
     return ret;
41
@@ -222,6 +237,7 @@
42
     // encoder now owns these analysisData buffers.
43
     if (pic_in)
44
     {
45
+        pic_in->analysisData.wt = NULL;
46
         pic_in->analysisData.intraData = NULL;
47
         pic_in->analysisData.interData = NULL;
48
         pic_in->analysis2Pass.analysisFramedata = NULL;
49
x265_2.3.tar.gz/source/encoder/bitcost.cpp -> x265_2.4.tar.gz/source/encoder/bitcost.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/bitcost.h -> x265_2.4.tar.gz/source/encoder/bitcost.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/encoder/dpb.cpp -> x265_2.4.tar.gz/source/encoder/dpb.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/dpb.h -> x265_2.4.tar.gz/source/encoder/dpb.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/encoder/encoder.cpp -> x265_2.4.tar.gz/source/encoder/encoder.cpp Changed
836
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -56,6 +56,7 @@
9
 {
10
     m_aborted = false;
11
     m_reconfigure = false;
12
+    m_reconfigureRc = false;
13
     m_encodedFrameNum = 0;
14
     m_pocLast = -1;
15
     m_curEncoder = 0;
16
@@ -79,12 +80,18 @@
17
     m_iFrameNum = 0;
18
     m_iPPSQpMinus26 = 0;
19
     m_rpsInSpsCount = 0;
20
+    m_cB = 1.0;
21
+    m_cR = 1.0;
22
     for (int i = 0; i < X265_MAX_FRAME_THREADS; i++)
23
         m_frameEncoder[i] = NULL;
24
-
25
     MotionEstimate::initScales();
26
-}
27
 
28
+#if ENABLE_DYNAMIC_HDR10
29
+    m_hdr10plus_api = hdr10plus_api_get();
30
+#endif
31
+
32
+    m_prevTonemapPayload.payload = NULL;
33
+}
34
 inline char *strcatFilename(const char *input, const char *suffix)
35
 {
36
     char *output = X265_MALLOC(char, strlen(input) + strlen(suffix) + 1);
37
@@ -345,10 +352,10 @@
38
         if (!name)
39
             name = defaultAnalysisFileName;
40
         const char* mode = m_param->analysisMode == X265_ANALYSIS_LOAD ? "rb" : "wb";
41
-        m_analysisFile = fopen(name, mode);
42
+        m_analysisFile = x265_fopen(name, mode);
43
         if (!m_analysisFile)
44
         {
45
-            x265_log(NULL, X265_LOG_ERROR, "Analysis load/save: failed to open file %s\n", name);
46
+            x265_log_file(NULL, X265_LOG_ERROR, "Analysis load/save: failed to open file %s\n", name);
47
             m_aborted = true;
48
         }
49
     }
50
@@ -365,21 +372,21 @@
51
                 m_aborted = true;
52
             else
53
             {
54
-                m_analysisFileOut = fopen(temp, "wb");
55
+                m_analysisFileOut = x265_fopen(temp, "wb");
56
                 X265_FREE(temp);
57
             }
58
             if (!m_analysisFileOut)
59
             {
60
-                x265_log(NULL, X265_LOG_ERROR, "Analysis 2 pass: failed to open file %s\n", temp);
61
+                x265_log_file(NULL, X265_LOG_ERROR, "Analysis 2 pass: failed to open file %s.temp\n", name);
62
                 m_aborted = true;
63
             }
64
         }
65
         if (m_param->rc.bStatRead)
66
         {
67
-            m_analysisFileIn = fopen(name, "rb");
68
+            m_analysisFileIn = x265_fopen(name, "rb");
69
             if (!m_analysisFileIn)
70
             {
71
-                x265_log(NULL, X265_LOG_ERROR, "Analysis 2 pass: failed to open file %s\n", name);
72
+                x265_log_file(NULL, X265_LOG_ERROR, "Analysis 2 pass: failed to open file %s\n", name);
73
                 m_aborted = true;
74
             }
75
         }
76
@@ -486,7 +493,7 @@
77
         }
78
         if (bError)
79
         {
80
-            x265_log(m_param, X265_LOG_ERROR, "failed to rename analysis stats file to \"%s\"\n", name);
81
+            x265_log_file(m_param, X265_LOG_ERROR, "failed to rename analysis stats file to \"%s\"\n", name);
82
         }
83
         X265_FREE(temp);
84
      }
85
@@ -499,7 +506,7 @@
86
         free((char*)m_param->scalingLists);
87
         free((char*)m_param->numaPools);
88
         free((char*)m_param->masteringDisplayColorVolume);
89
-
90
+        free((char*)m_param->toneMapFile);
91
         PARAM_NS::x265_param_free(m_param);
92
     }
93
 }
94
@@ -590,9 +597,24 @@
95
         m_exportedPic = NULL;
96
         m_dpb->recycleUnreferenced();
97
     }
98
-
99
     if (pic_in)
100
     {
101
+        x265_sei_payload toneMap;
102
+        toneMap.payload = NULL;
103
+#if ENABLE_DYNAMIC_HDR10
104
+        if (m_bToneMap)
105
+        {
106
+            uint8_t *cim = NULL;
107
+            if (m_hdr10plus_api->hdr10plus_json_to_frame_cim(m_param->toneMapFile, pic_in->poc, cim))
108
+            {
109
+                toneMap.payload = (uint8_t*)x265_malloc(sizeof(uint8_t) * cim[0]);
110
+                toneMap.payloadSize = cim[0];
111
+                toneMap.payloadType = USER_DATA_REGISTERED_ITU_T_T35;
112
+                memcpy(toneMap.payload, cim, toneMap.payloadSize);
113
+            }
114
+        }
115
+#endif
116
+
117
         if (pic_in->bitDepth < 8 || pic_in->bitDepth > 16)
118
         {
119
             x265_log(m_param, X265_LOG_ERROR, "Input bit depth (%d) must be between 8 and 16\n",
120
@@ -605,7 +627,7 @@
121
         {
122
             inFrame = new Frame;
123
             inFrame->m_encodeStartTime = x265_mdate();
124
-            x265_param* p = m_reconfigure ? m_latestParam : m_param;
125
+            x265_param* p = (m_reconfigure || m_reconfigureRc) ? m_latestParam : m_param;
126
             if (inFrame->create(p, pic_in->quantOffsets))
127
             {
128
                 /* the first PicYuv created is asked to generate the CU and block unit offset
129
@@ -672,19 +694,31 @@
130
         inFrame->m_userData  = pic_in->userData;
131
         inFrame->m_pts       = pic_in->pts;
132
         inFrame->m_forceqp   = pic_in->forceqp;
133
-        inFrame->m_param     = m_reconfigure ? m_latestParam : m_param;
134
+        inFrame->m_param     = (m_reconfigure || m_reconfigureRc) ? m_latestParam : m_param;
135
 
136
-        if (pic_in->userSEI.numPayloads)
137
+        int toneMapEnable = 0;
138
+        if (m_bToneMap && toneMap.payload)
139
+            toneMapEnable = 1;
140
+        int numPayloads = pic_in->userSEI.numPayloads + toneMapEnable;
141
+        inFrame->m_userSEI.numPayloads = numPayloads;
142
+
143
+        if (inFrame->m_userSEI.numPayloads)
144
         {
145
-            int numPayloads = inFrame->m_userSEI.numPayloads = pic_in->userSEI.numPayloads;
146
             inFrame->m_userSEI.payloads = new x265_sei_payload[numPayloads];
147
             for (int i = 0; i < numPayloads; i++)
148
             {
149
-                int size = inFrame->m_userSEI.payloads[i].payloadSize = pic_in->userSEI.payloads[i].payloadSize;
150
-                inFrame->m_userSEI.payloads[i].payloadType = pic_in->userSEI.payloads[i].payloadType;
151
+                x265_sei_payload input;
152
+                if (i == (numPayloads - 1))
153
+                    input = toneMap;
154
+                else
155
+                    input = pic_in->userSEI.payloads[i];
156
+                int size = inFrame->m_userSEI.payloads[i].payloadSize = input.payloadSize;
157
+                inFrame->m_userSEI.payloads[i].payloadType = input.payloadType;
158
                 inFrame->m_userSEI.payloads[i].payload = new uint8_t[size];
159
-                memcpy(inFrame->m_userSEI.payloads[i].payload, pic_in->userSEI.payloads[i].payload, size);
160
+                memcpy(inFrame->m_userSEI.payloads[i].payload, input.payload, size);
161
             }
162
+            if (toneMap.payload)
163
+                x265_free(toneMap.payload);
164
         }
165
 
166
         if (pic_in->quantOffsets != NULL)
167
@@ -731,12 +765,15 @@
168
             inFrame->m_analysisData.satdCost = inputPic->analysisData.satdCost;
169
             inFrame->m_analysisData.numCUsInFrame = inputPic->analysisData.numCUsInFrame;
170
             inFrame->m_analysisData.numPartitions = inputPic->analysisData.numPartitions;
171
+            inFrame->m_analysisData.wt = inputPic->analysisData.wt;
172
             inFrame->m_analysisData.interData = inputPic->analysisData.interData;
173
             inFrame->m_analysisData.intraData = inputPic->analysisData.intraData;
174
             sliceType = inputPic->analysisData.sliceType;
175
             inFrame->m_lowres.bScenecut = !!inFrame->m_analysisData.bScenecut;
176
             inFrame->m_lowres.satdCost = inFrame->m_analysisData.satdCost;
177
         }
178
+        if (m_reconfigureRc)
179
+            inFrame->m_reconfigureRc = true;
180
 
181
         m_lookahead->addPicture(*inFrame, sliceType);
182
         m_numDelayedPic++;
183
@@ -815,6 +852,7 @@
184
                     pic_out->analysisData.satdCost  = outFrame->m_lowres.satdCost;                    
185
                     pic_out->analysisData.numCUsInFrame = outFrame->m_analysisData.numCUsInFrame;
186
                     pic_out->analysisData.numPartitions = outFrame->m_analysisData.numPartitions;
187
+                    pic_out->analysisData.wt = outFrame->m_analysisData.wt;
188
                     pic_out->analysisData.interData = outFrame->m_analysisData.interData;
189
                     pic_out->analysisData.intraData = outFrame->m_analysisData.intraData;
190
                     writeAnalysisFile(&pic_out->analysisData, *outFrame->m_encData);
191
@@ -936,6 +974,15 @@
192
                 if (m_param->rc.bStatRead)
193
                     readAnalysis2PassFile(&frameEnc->m_analysis2Pass, frameEnc->m_poc, frameEnc->m_lowres.sliceType);
194
              }
195
+
196
+            if (frameEnc->m_reconfigureRc && m_reconfigureRc)
197
+            {
198
+                memcpy(m_param, m_latestParam, sizeof(x265_param));
199
+                m_rateControl->reconfigureRC();
200
+                m_reconfigureRc = false;
201
+            }
202
+            if (frameEnc->m_reconfigureRc && !m_reconfigureRc)
203
+                frameEnc->m_reconfigureRc = false;
204
             if (curEncoder->m_reconfigure)
205
             {
206
                 /* One round robin cycle of FE reconfigure is complete */
207
@@ -1086,6 +1133,25 @@
208
     encParam->bIntraInBFrames = param->bIntraInBFrames;
209
     if (param->scalingLists && !encParam->scalingLists)
210
         encParam->scalingLists = strdup(param->scalingLists);
211
+    /* VBV can't be turned ON if it wasn't ON to begin with and can't be turned OFF if it was ON to begin with*/
212
+    if (param->rc.vbvMaxBitrate > 0 && param->rc.vbvBufferSize > 0 &&
213
+        encParam->rc.vbvMaxBitrate > 0 && encParam->rc.vbvBufferSize > 0)
214
+    {
215
+        m_reconfigureRc |= encParam->rc.vbvMaxBitrate != param->rc.vbvMaxBitrate;
216
+        m_reconfigureRc |= encParam->rc.vbvBufferSize != param->rc.vbvBufferSize;
217
+        if (m_reconfigureRc && m_param->bEmitHRDSEI)
218
+            x265_log(m_param, X265_LOG_WARNING, "VBV parameters cannot be changed when HRD is in use.\n");
219
+        else
220
+        {
221
+            encParam->rc.vbvMaxBitrate = param->rc.vbvMaxBitrate;
222
+            encParam->rc.vbvBufferSize = param->rc.vbvBufferSize;
223
+        }
224
+    }
225
+    m_reconfigureRc |= encParam->rc.bitrate != param->rc.bitrate;
226
+    encParam->rc.bitrate = param->rc.bitrate;
227
+    m_reconfigureRc |= encParam->rc.rfConstant != param->rc.rfConstant;
228
+    encParam->rc.rfConstant = param->rc.rfConstant; 
229
+
230
     /* To add: Loop Filter/deblocking controls, transform skip, signhide require PPS to be resent */
231
     /* To add: SAO, temporal MVP, AMP, TU depths require SPS to be resent, at every CVS boundary */
232
     return x265_check_params(encParam);
233
@@ -1689,15 +1755,14 @@
234
             if (buffer)
235
             {
236
                 sprintf(buffer, "x265 (build %d) - %s:%s - H.265/HEVC codec - "
237
-                        "Copyright 2013-2016 (c) Multicoreware Inc - "
238
+                        "Copyright 2013-2017 (c) Multicoreware, Inc - "
239
                         "http://x265.org - options: %s",
240
                         X265_BUILD, PFX(version_str), PFX(build_info_str), opts);
241
                 
242
                 bs.resetBits();
243
                 SEIuserDataUnregistered idsei;
244
-                idsei.m_payloadType = USER_DATA_UNREGISTERED;
245
                 idsei.m_userData = (uint8_t*)buffer;
246
-                idsei.m_userDataLength = (uint32_t)strlen(buffer);
247
+                idsei.setSize((uint32_t)strlen(buffer));
248
                 idsei.write(bs, m_sps);
249
                 bs.writeByteAlignment();
250
                 list.serialize(NAL_UNIT_PREFIX_SEI, bs);
251
@@ -1829,6 +1894,7 @@
252
 
253
     pps->chromaQpOffset[0] = m_param->cbQpOffset;
254
     pps->chromaQpOffset[1] = m_param->crQpOffset;
255
+    pps->pps_slice_chroma_qp_offsets_present_flag = m_param->bHDROpt;
256
 
257
     pps->bConstrainedIntraPred = m_param->bEnableConstrainedIntra;
258
     pps->bUseWeightPred = m_param->bEnableWeightedPred;
259
@@ -2104,7 +2170,7 @@
260
     /* some options make no sense if others are disabled */
261
     p->bSaoNonDeblocked &= p->bEnableSAO;
262
     p->bEnableTSkipFast &= p->bEnableTransformSkip;
263
-
264
+    p->bLimitSAO &= p->bEnableSAO;
265
     /* initialize the conformance window */
266
     m_conformanceWindow.bEnabled = false;
267
     m_conformanceWindow.rightOffset = 0;
268
@@ -2162,6 +2228,40 @@
269
         p->dynamicRd = 0;
270
         x265_log(p, X265_LOG_WARNING, "Dynamic-rd disabled, requires RD <= 4, VBV and aq-mode enabled\n");
271
     }
272
+#ifdef ENABLE_DYNAMIC_HDR10
273
+    if (m_param->bDhdr10opt && m_param->toneMapFile == NULL)
274
+    {
275
+        x265_log(p, X265_LOG_WARNING, "Disabling dhdr10-opt. dhdr10-info must be enabled.\n");
276
+        m_param->bDhdr10opt = 0;
277
+    }
278
+
279
+    if (m_param->toneMapFile)
280
+    {
281
+        if (!x265_fopen(p->toneMapFile, "r"))
282
+        {
283
+            x265_log(p, X265_LOG_ERROR, "Unable to open tone-map file.\n");
284
+            m_bToneMap = 0;
285
+            m_param->toneMapFile = NULL;
286
+            m_aborted = true;
287
+        }
288
+        else
289
+            m_bToneMap = 1;
290
+    }
291
+    else
292
+        m_bToneMap = 0;
293
+#else
294
+    if (m_param->toneMapFile)
295
+    {
296
+        x265_log(p, X265_LOG_WARNING, "--dhdr10-info disabled. Enable dynamic HDR in cmake.\n");
297
+        m_bToneMap = 0;
298
+        m_param->toneMapFile = NULL;
299
+    }
300
+    else if (m_param->bDhdr10opt)
301
+    {
302
+        x265_log(p, X265_LOG_WARNING, "Disabling dhdr10-opt. dhdr10-info must be enabled.\n");
303
+        m_param->bDhdr10opt = 0;
304
+    }
305
+#endif
306
 
307
     if (p->uhdBluray)
308
     {
309
@@ -2286,14 +2386,26 @@
310
         x265_log(p, X265_LOG_WARNING, "maxSlices can not be less than 1, force set to 1\n");
311
         p->maxSlices = 1;
312
     }
313
-
314
     const uint32_t numRows = (p->sourceHeight + p->maxCUSize - 1) / p->maxCUSize;
315
     const uint32_t slicesLimit = X265_MIN(numRows, NALList::MAX_NAL_UNITS - 1);
316
-    if (p->maxSlices > numRows)
317
+    if (p->maxSlices > slicesLimit)
318
     {
319
         x265_log(p, X265_LOG_WARNING, "maxSlices can not be more than min(rows, MAX_NAL_UNITS-1), force set to %d\n", slicesLimit);
320
         p->maxSlices = slicesLimit;
321
     }
322
+    if (p->bHDROpt)
323
+    {
324
+        if (p->internalCsp != X265_CSP_I420 || p->internalBitDepth != 10 || p->vui.colorPrimaries != 9 ||
325
+            p->vui.transferCharacteristics != 16 || p->vui.matrixCoeffs != 9)
326
+        {
327
+            x265_log(p, X265_LOG_ERROR, "Recommended Settings for HDR: colour primaries should be BT.2020,\n"
328
+                                        "                                            transfer characteristics should be SMPTE ST.2084,\n"
329
+                                        "                                            matrix coeffs should be BT.2020,\n"
330
+                                        "                                            the input video should be 10 bit 4:2:0\n"
331
+                                        "                                            Disabling offset tuning for HDR videos\n");
332
+            p->bHDROpt = 0;
333
+        }
334
+    }
335
 }
336
 
337
 void Encoder::allocAnalysis(x265_analysis_data* analysis)
338
@@ -2302,6 +2414,9 @@
339
     analysis->interData = analysis->intraData = NULL;
340
     if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
341
     {
342
+        if (m_param->analysisRefineLevel < 2)
343
+            return;
344
+
345
         analysis_intra_data *intraData = (analysis_intra_data*)analysis->intraData;
346
         CHECKED_MALLOC_ZERO(intraData, analysis_intra_data, 1);
347
         CHECKED_MALLOC(intraData->depth, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
348
@@ -2313,14 +2428,44 @@
349
     else
350
     {
351
         int numDir = analysis->sliceType == X265_TYPE_P ? 1 : 2;
352
+        uint32_t numPlanes = m_param->internalCsp == X265_CSP_I400 ? 1 : 3;
353
+        CHECKED_MALLOC_ZERO(analysis->wt, WeightParam, numPlanes * numDir);
354
+        if (m_param->analysisRefineLevel < 2)
355
+            return;
356
+
357
         analysis_inter_data *interData = (analysis_inter_data*)analysis->interData;
358
         CHECKED_MALLOC_ZERO(interData, analysis_inter_data, 1);
359
-        CHECKED_MALLOC_ZERO(interData->ref, int32_t, analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir);
360
         CHECKED_MALLOC(interData->depth, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
361
         CHECKED_MALLOC(interData->modes, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
362
-        CHECKED_MALLOC(interData->partSize, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
363
-        CHECKED_MALLOC(interData->mergeFlag, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
364
-        CHECKED_MALLOC_ZERO(interData->wt, WeightParam, 3 * numDir);
365
+        if (m_param->analysisRefineLevel > 4)
366
+        {
367
+            CHECKED_MALLOC(interData->partSize, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
368
+            CHECKED_MALLOC(interData->mergeFlag, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
369
+        }
370
+
371
+        if (m_param->analysisRefineLevel == 10)
372
+        {
373
+            CHECKED_MALLOC(interData->interDir, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
374
+            for (int dir = 0; dir < numDir; dir++)
375
+            {
376
+                CHECKED_MALLOC(interData->mvpIdx[dir], uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
377
+                CHECKED_MALLOC(interData->refIdx[dir], int8_t, analysis->numPartitions * analysis->numCUsInFrame);
378
+               CHECKED_MALLOC(interData->mv[dir], MV, analysis->numPartitions * analysis->numCUsInFrame);
379
+            }
380
+
381
+            /* Allocate intra in inter */
382
+            if (analysis->sliceType == X265_TYPE_P || m_param->bIntraInBFrames)
383
+            {
384
+                analysis_intra_data *intraData = (analysis_intra_data*)analysis->intraData;
385
+                CHECKED_MALLOC_ZERO(intraData, analysis_intra_data, 1);
386
+                CHECKED_MALLOC(intraData->modes, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
387
+                CHECKED_MALLOC(intraData->chromaModes, uint8_t, analysis->numPartitions * analysis->numCUsInFrame);
388
+                analysis->intraData = intraData;
389
+            }
390
+        }
391
+        else
392
+            CHECKED_MALLOC_ZERO(interData->ref, int32_t, analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir);
393
+
394
         analysis->interData = interData;
395
     }
396
     return;
397
@@ -2332,22 +2477,53 @@
398
 
399
 void Encoder::freeAnalysis(x265_analysis_data* analysis)
400
 {
401
+    /* Early exit freeing weights alone if level is 1 (when there is no analysis inter/intra) */
402
+    if (analysis->sliceType > X265_TYPE_I && analysis->wt)
403
+        X265_FREE(analysis->wt);
404
+    if (m_param->analysisRefineLevel < 2)
405
+        return;
406
+
407
     if (analysis->intraData)
408
     {
409
+        if (m_param->analysisRefineLevel < 2)
410
+            return;
411
+
412
         X265_FREE(((analysis_intra_data*)analysis->intraData)->depth);
413
         X265_FREE(((analysis_intra_data*)analysis->intraData)->modes);
414
         X265_FREE(((analysis_intra_data*)analysis->intraData)->partSizes);
415
         X265_FREE(((analysis_intra_data*)analysis->intraData)->chromaModes);
416
         X265_FREE(analysis->intraData);
417
     }
418
-    else
419
+    else if (analysis->interData)
420
     {
421
-        X265_FREE(((analysis_inter_data*)analysis->interData)->ref);
422
         X265_FREE(((analysis_inter_data*)analysis->interData)->depth);
423
         X265_FREE(((analysis_inter_data*)analysis->interData)->modes);
424
-        X265_FREE(((analysis_inter_data*)analysis->interData)->mergeFlag);
425
-        X265_FREE(((analysis_inter_data*)analysis->interData)->partSize);
426
-        X265_FREE(((analysis_inter_data*)analysis->interData)->wt);
427
+        if (m_param->analysisRefineLevel > 4)
428
+        {
429
+            X265_FREE(((analysis_inter_data*)analysis->interData)->mergeFlag);
430
+            X265_FREE(((analysis_inter_data*)analysis->interData)->partSize);
431
+        }
432
+
433
+        if (m_param->analysisRefineLevel == 10)
434
+        {
435
+            X265_FREE(((analysis_inter_data*)analysis->interData)->interDir);
436
+            int numDir = analysis->sliceType == X265_TYPE_P ? 1 : 2;
437
+            for (int dir = 0; dir < numDir; dir++)
438
+            {
439
+                X265_FREE(((analysis_inter_data*)analysis->interData)->mvpIdx[dir]);
440
+                X265_FREE(((analysis_inter_data*)analysis->interData)->refIdx[dir]);
441
+                X265_FREE(((analysis_inter_data*)analysis->interData)->mv[dir]);
442
+            }
443
+            if (analysis->sliceType == P_SLICE || m_param->bIntraInBFrames)
444
+            {
445
+                X265_FREE(((analysis_intra_data*)analysis->intraData)->modes);
446
+                X265_FREE(((analysis_intra_data*)analysis->intraData)->chromaModes);
447
+                X265_FREE(analysis->intraData);
448
+            }
449
+        }
450
+        else
451
+            X265_FREE(((analysis_inter_data*)analysis->interData)->ref);
452
+
453
         X265_FREE(analysis->interData);
454
     }
455
 }
456
@@ -2472,6 +2648,10 @@
457
 
458
     if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
459
     {
460
+        analysis->sliceType = X265_TYPE_I;
461
+        if (m_param->analysisRefineLevel < 2)
462
+            return;
463
+
464
         uint8_t *tempBuf = NULL, *depthBuf = NULL, *modeBuf = NULL, *partSizes = NULL;
465
 
466
         tempBuf = X265_MALLOC(uint8_t, depthBytes * 3);
467
@@ -2492,21 +2672,55 @@
468
         }
469
         X265_FREAD(((analysis_intra_data *)analysis->intraData)->modes, sizeof(uint8_t), analysis->numCUsInFrame * analysis->numPartitions, m_analysisFile);
470
         X265_FREE(tempBuf);
471
-        analysis->sliceType = X265_TYPE_I;
472
         consumedBytes += frameRecordSize;
473
     }
474
 
475
     else
476
     {
477
+        uint32_t numDir = analysis->sliceType == X265_TYPE_P ? 1 : 2;
478
+        uint32_t numPlanes = m_param->internalCsp == X265_CSP_I400 ? 1 : 3;
479
+        X265_FREAD((WeightParam*)analysis->wt, sizeof(WeightParam), numPlanes * numDir, m_analysisFile);
480
+        if (m_param->analysisRefineLevel < 2)
481
+            return;
482
+
483
         uint8_t *tempBuf = NULL, *depthBuf = NULL, *modeBuf = NULL, *partSize = NULL, *mergeFlag = NULL;
484
+        uint8_t *interDir = NULL, *chromaDir = NULL, *mvpIdx[2];
485
+        MV* mv[2];
486
+        int8_t* refIdx[2];
487
+
488
+        int numBuf = m_param->analysisRefineLevel > 4 ? 4 : 2;
489
+        bool bIntraInInter = false;
490
+        if (m_param->analysisRefineLevel == 10)
491
+        {
492
+            numBuf++;
493
+            bIntraInInter = (analysis->sliceType == X265_TYPE_P || m_param->bIntraInBFrames);
494
+            if (bIntraInInter) numBuf++;
495
+        }
496
 
497
-        tempBuf = X265_MALLOC(uint8_t, depthBytes * 4);
498
-        X265_FREAD(tempBuf, sizeof(uint8_t), depthBytes * 4, m_analysisFile);
499
+        tempBuf = X265_MALLOC(uint8_t, depthBytes * numBuf);
500
+        X265_FREAD(tempBuf, sizeof(uint8_t), depthBytes * numBuf, m_analysisFile);
501
 
502
         depthBuf = tempBuf;
503
         modeBuf = tempBuf + depthBytes;
504
-        partSize = modeBuf + depthBytes;
505
-        mergeFlag = partSize + depthBytes;
506
+        if (m_param->analysisRefineLevel > 4)
507
+        {
508
+            partSize = modeBuf + depthBytes;
509
+            mergeFlag = partSize + depthBytes;
510
+            if (m_param->analysisRefineLevel == 10)
511
+            {
512
+                interDir = mergeFlag + depthBytes;
513
+                if (bIntraInInter) chromaDir = interDir + depthBytes;
514
+                for (uint32_t i = 0; i < numDir; i++)
515
+                {
516
+                    mvpIdx[i] = X265_MALLOC(uint8_t, depthBytes * 3);
517
+                    X265_FREAD(mvpIdx[i], sizeof(uint8_t), depthBytes, m_analysisFile);
518
+                    refIdx[i] = X265_MALLOC(int8_t, depthBytes);
519
+                    X265_FREAD(refIdx[i], sizeof(int8_t), depthBytes, m_analysisFile);
520
+                    mv[i] = X265_MALLOC(MV, depthBytes);
521
+                    X265_FREAD(mv[i], sizeof(MV), depthBytes, m_analysisFile);
522
+                }
523
+            }
524
+        }
525
 
526
         size_t count = 0;
527
         for (uint32_t d = 0; d < depthBytes; d++)
528
@@ -2514,17 +2728,47 @@
529
             int bytes = analysis->numPartitions >> (depthBuf[d] * 2);
530
             memset(&((analysis_inter_data *)analysis->interData)->depth[count], depthBuf[d], bytes);
531
             memset(&((analysis_inter_data *)analysis->interData)->modes[count], modeBuf[d], bytes);
532
-            memset(&((analysis_inter_data *)analysis->interData)->partSize[count], partSize[d], bytes);
533
-            memset(&((analysis_inter_data *)analysis->interData)->mergeFlag[count], mergeFlag[d], bytes);
534
+            if (m_param->analysisRefineLevel > 4)
535
+            {
536
+                memset(&((analysis_inter_data *)analysis->interData)->partSize[count], partSize[d], bytes);
537
+                int numPU = nbPartsTable[(int)partSize[d]];
538
+                for (int pu = 0; pu < numPU; pu++)
539
+                {
540
+                    if (pu) d++;
541
+                    ((analysis_inter_data *)analysis->interData)->mergeFlag[count + pu] = mergeFlag[d];
542
+                    if (m_param->analysisRefineLevel == 10)
543
+                    {
544
+                        ((analysis_inter_data *)analysis->interData)->interDir[count + pu] = interDir[d];
545
+                        for (uint32_t i = 0; i < numDir; i++)
546
+                        {
547
+                            ((analysis_inter_data *)analysis->interData)->mvpIdx[i][count + pu] = mvpIdx[i][d];
548
+                            ((analysis_inter_data *)analysis->interData)->refIdx[i][count + pu] = refIdx[i][d];
549
+                            memcpy(&((analysis_inter_data *)analysis->interData)->mv[i][count + pu], &mv[i][d], sizeof(MV));
550
+                        }
551
+                    }
552
+                }
553
+                if (m_param->analysisRefineLevel == 10 && bIntraInInter)
554
+                    memset(&((analysis_intra_data *)analysis->intraData)->chromaModes[count], chromaDir[d], bytes);
555
+            }
556
             count += bytes;
557
         }
558
 
559
         X265_FREE(tempBuf);
560
 
561
-        int numDir = analysis->sliceType == X265_TYPE_P ? 1 : 2;
562
-        X265_FREAD(((analysis_inter_data *)analysis->interData)->ref, sizeof(int32_t), analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir, m_analysisFile);
563
-        uint32_t numPlanes = m_param->internalCsp == X265_CSP_I400 ? 1 : 3;
564
-        X265_FREAD(((analysis_inter_data *)analysis->interData)->wt, sizeof(WeightParam), numPlanes * numDir, m_analysisFile);
565
+        if (m_param->analysisRefineLevel == 10)
566
+        {
567
+            for (uint32_t i = 0; i < numDir; i++)
568
+            {
569
+                X265_FREE(mvpIdx[i]);
570
+                X265_FREE(refIdx[i]);
571
+                X265_FREE(mv[i]);
572
+            }
573
+            if (bIntraInInter)
574
+                X265_FREAD(((analysis_intra_data *)analysis->intraData)->modes, sizeof(uint8_t), analysis->numCUsInFrame * analysis->numPartitions, m_analysisFile);
575
+        }
576
+        else
577
+            X265_FREAD(((analysis_inter_data *)analysis->interData)->ref, sizeof(int32_t), analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir, m_analysisFile);
578
+
579
         consumedBytes += frameRecordSize;
580
         if (numDir == 1)
581
             totalConsumedBytes = consumedBytes;
582
@@ -2670,78 +2914,128 @@
583
     }\
584
 
585
     uint32_t depthBytes = 0;
586
-    if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
587
+    uint32_t numDir, numPlanes;
588
+    bool bIntraInInter = false;
589
+
590
+    /* calculate frameRecordSize */
591
+    analysis->frameRecordSize = sizeof(analysis->frameRecordSize) + sizeof(depthBytes) + sizeof(analysis->poc) + sizeof(analysis->sliceType) +
592
+                      sizeof(analysis->numCUsInFrame) + sizeof(analysis->numPartitions) + sizeof(analysis->bScenecut) + sizeof(analysis->satdCost);
593
+    if (analysis->sliceType > X265_TYPE_I)
594
     {
595
-        for (uint32_t cuAddr = 0; cuAddr < analysis->numCUsInFrame; cuAddr++)
596
+        numDir = (analysis->sliceType == X265_TYPE_P) ? 1 : 2;
597
+        numPlanes = m_param->internalCsp == X265_CSP_I400 ? 1 : 3;
598
+        analysis->frameRecordSize += sizeof(WeightParam) * numPlanes * numDir;
599
+    }
600
+
601
+    if (m_param->analysisRefineLevel > 1)
602
+    {
603
+        if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
604
         {
605
-            uint8_t depth = 0;
606
-            uint8_t mode = 0;
607
-            uint8_t partSize = 0;
608
+            for (uint32_t cuAddr = 0; cuAddr < analysis->numCUsInFrame; cuAddr++)
609
+            {
610
+                uint8_t depth = 0;
611
+                uint8_t mode = 0;
612
+                uint8_t partSize = 0;
613
 
614
-            CUData* ctu = curEncData.getPicCTU(cuAddr);
615
-            analysis_intra_data* intraDataCTU = (analysis_intra_data*)analysis->intraData;
616
+                CUData* ctu = curEncData.getPicCTU(cuAddr);
617
+                analysis_intra_data* intraDataCTU = (analysis_intra_data*)analysis->intraData;
618
 
619
-            for (uint32_t absPartIdx = 0; absPartIdx < ctu->m_numPartitions; depthBytes++)
620
-            {
621
-                depth = ctu->m_cuDepth[absPartIdx];
622
-                intraDataCTU->depth[depthBytes] = depth;
623
+                for (uint32_t absPartIdx = 0; absPartIdx < ctu->m_numPartitions; depthBytes++)
624
+                {
625
+                    depth = ctu->m_cuDepth[absPartIdx];
626
+                    intraDataCTU->depth[depthBytes] = depth;
627
 
628
-                mode = ctu->m_chromaIntraDir[absPartIdx];
629
-                intraDataCTU->chromaModes[depthBytes] = mode;
630
+                    mode = ctu->m_chromaIntraDir[absPartIdx];
631
+                    intraDataCTU->chromaModes[depthBytes] = mode;
632
 
633
-                partSize = ctu->m_partSize[absPartIdx];
634
-                intraDataCTU->partSizes[depthBytes] = partSize;
635
+                    partSize = ctu->m_partSize[absPartIdx];
636
+                    intraDataCTU->partSizes[depthBytes] = partSize;
637
 
638
-                absPartIdx += ctu->m_numPartitions >> (depth * 2);
639
+                    absPartIdx += ctu->m_numPartitions >> (depth * 2);
640
+                }
641
+                memcpy(&intraDataCTU->modes[ctu->m_cuAddr * ctu->m_numPartitions], ctu->m_lumaIntraDir, sizeof(uint8_t)* ctu->m_numPartitions);
642
             }
643
-            memcpy(&intraDataCTU->modes[ctu->m_cuAddr * ctu->m_numPartitions], ctu->m_lumaIntraDir, sizeof(uint8_t)* ctu->m_numPartitions);
644
         }
645
-    }
646
-    else
647
-    {
648
-        for (uint32_t cuAddr = 0; cuAddr < analysis->numCUsInFrame; cuAddr++)
649
+        else
650
         {
651
-            uint8_t depth = 0;
652
-            uint8_t predMode = 0;
653
-            uint8_t partSize = 0;
654
-            uint8_t mergeFlag = 0;
655
-
656
-            CUData* ctu = curEncData.getPicCTU(cuAddr);
657
-            analysis_inter_data* interDataCTU = (analysis_inter_data*)analysis->interData;
658
-
659
-            for (uint32_t absPartIdx = 0; absPartIdx < ctu->m_numPartitions; depthBytes++)
660
+            bIntraInInter = (analysis->sliceType == X265_TYPE_P || m_param->bIntraInBFrames);
661
+            for (uint32_t cuAddr = 0; cuAddr < analysis->numCUsInFrame; cuAddr++)
662
             {
663
-                depth = ctu->m_cuDepth[absPartIdx];
664
-                interDataCTU->depth[depthBytes] = depth;
665
+                uint8_t depth = 0;
666
+                uint8_t predMode = 0;
667
+                uint8_t partSize = 0;
668
+
669
+                CUData* ctu = curEncData.getPicCTU(cuAddr);
670
+                analysis_inter_data* interDataCTU = (analysis_inter_data*)analysis->interData;
671
+                analysis_intra_data* intraDataCTU = (analysis_intra_data*)analysis->intraData;
672
 
673
-                predMode = ctu->m_predMode[absPartIdx];
674
-                if (ctu->m_refIdx[1][absPartIdx] != -1)
675
-                    predMode = 4; // used as indiacator if the block is coded as bidir
676
+                for (uint32_t absPartIdx = 0; absPartIdx < ctu->m_numPartitions; depthBytes++)
677
+                {
678
+                    depth = ctu->m_cuDepth[absPartIdx];
679
+                    interDataCTU->depth[depthBytes] = depth;
680
 
681
-                interDataCTU->modes[depthBytes] = predMode;
682
+                    predMode = ctu->m_predMode[absPartIdx];
683
+                    if (m_param->analysisRefineLevel != 10 && ctu->m_refIdx[1][absPartIdx] != -1)
684
+                        predMode = 4; // used as indiacator if the block is coded as bidir
685
 
686
-                partSize = ctu->m_partSize[absPartIdx];
687
-                interDataCTU->partSize[depthBytes] = partSize;
688
+                    interDataCTU->modes[depthBytes] = predMode;
689
 
690
-                mergeFlag = ctu->m_mergeFlag[absPartIdx];
691
-                interDataCTU->mergeFlag[depthBytes] = mergeFlag;
692
+                    if (m_param->analysisRefineLevel > 4)
693
+                    {
694
+                        partSize = ctu->m_partSize[absPartIdx];
695
+                        interDataCTU->partSize[depthBytes] = partSize;
696
 
697
-                absPartIdx += ctu->m_numPartitions >> (depth * 2);
698
+                        /* Store per PU data */
699
+                        uint32_t numPU = nbPartsTable[(int)partSize];
700
+                        for (uint32_t puIdx = 0; puIdx < numPU; puIdx++)
701
+                        {
702
+                            uint32_t puabsPartIdx = ctu->getPUOffset(puIdx, absPartIdx) + absPartIdx;
703
+                            if (puIdx) depthBytes++;
704
+                            interDataCTU->mergeFlag[depthBytes] = ctu->m_mergeFlag[puabsPartIdx];
705
+
706
+                            if (m_param->analysisRefineLevel == 10)
707
+                            {
708
+                                interDataCTU->interDir[depthBytes] = ctu->m_interDir[puabsPartIdx];
709
+                                for (uint32_t dir = 0; dir < numDir; dir++)
710
+                                {
711
+                                    interDataCTU->mvpIdx[dir][depthBytes] = ctu->m_mvpIdx[dir][puabsPartIdx];
712
+                                    interDataCTU->refIdx[dir][depthBytes] = ctu->m_refIdx[dir][puabsPartIdx];
713
+                                    interDataCTU->mv[dir][depthBytes] = ctu->m_mv[dir][puabsPartIdx];
714
+                                }
715
+                            }
716
+                        }
717
+                        if (m_param->analysisRefineLevel == 10 && bIntraInInter)
718
+                            intraDataCTU->chromaModes[depthBytes] = ctu->m_chromaIntraDir[absPartIdx];
719
+                    }
720
+                    absPartIdx += ctu->m_numPartitions >> (depth * 2);
721
+                }
722
+                if (m_param->analysisRefineLevel == 10 && bIntraInInter)
723
+                    memcpy(&intraDataCTU->modes[ctu->m_cuAddr * ctu->m_numPartitions], ctu->m_lumaIntraDir, sizeof(uint8_t)* ctu->m_numPartitions);
724
             }
725
         }
726
-    }
727
 
728
-    /* calculate frameRecordSize */
729
-    analysis->frameRecordSize = sizeof(analysis->frameRecordSize) + sizeof(depthBytes) + sizeof(analysis->poc) + sizeof(analysis->sliceType) +
730
-                      sizeof(analysis->numCUsInFrame) + sizeof(analysis->numPartitions) + sizeof(analysis->bScenecut) + sizeof(analysis->satdCost);
731
-    if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
732
-        analysis->frameRecordSize += sizeof(uint8_t)* analysis->numCUsInFrame * analysis->numPartitions + depthBytes * 3;
733
-    else
734
-    {
735
-        int numDir = (analysis->sliceType == X265_TYPE_P) ? 1 : 2;
736
-        analysis->frameRecordSize += depthBytes * 4;
737
-        analysis->frameRecordSize += sizeof(int32_t)* analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir;
738
-        analysis->frameRecordSize += sizeof(WeightParam)* 3 * numDir;
739
+        if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
740
+            analysis->frameRecordSize += sizeof(uint8_t)* analysis->numCUsInFrame * analysis->numPartitions + depthBytes * 3;
741
+        else
742
+        {
743
+            /* Add sizeof depth, modes, partSize, mergeFlag */
744
+            analysis->frameRecordSize += depthBytes * 2;
745
+            if (m_param->analysisRefineLevel > 4)
746
+                analysis->frameRecordSize += (depthBytes * 2);
747
+
748
+            if (m_param->analysisRefineLevel == 10)
749
+            {
750
+                /* Add Size of interDir, mvpIdx, refIdx, mv, luma and chroma modes */
751
+                analysis->frameRecordSize += depthBytes;
752
+                analysis->frameRecordSize += sizeof(uint8_t)* depthBytes * numDir;
753
+                analysis->frameRecordSize += sizeof(int8_t)* depthBytes * numDir;
754
+                analysis->frameRecordSize += sizeof(MV)* depthBytes * numDir;
755
+                if (bIntraInInter)
756
+                    analysis->frameRecordSize += sizeof(uint8_t)* analysis->numCUsInFrame * analysis->numPartitions + depthBytes;
757
+            }
758
+            else
759
+                analysis->frameRecordSize += sizeof(int32_t)* analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir;
760
+        }
761
     }
762
     X265_FWRITE(&analysis->frameRecordSize, sizeof(uint32_t), 1, m_analysisFile);
763
     X265_FWRITE(&depthBytes, sizeof(uint32_t), 1, m_analysisFile);
764
@@ -2751,6 +3045,11 @@
765
     X265_FWRITE(&analysis->satdCost, sizeof(int64_t), 1, m_analysisFile);
766
     X265_FWRITE(&analysis->numCUsInFrame, sizeof(int), 1, m_analysisFile);
767
     X265_FWRITE(&analysis->numPartitions, sizeof(int), 1, m_analysisFile);
768
+    if (analysis->sliceType > X265_TYPE_I)
769
+        X265_FWRITE((WeightParam*)analysis->wt, sizeof(WeightParam), numPlanes * numDir, m_analysisFile);
770
+
771
+    if (m_param->analysisRefineLevel < 2)
772
+        return;
773
 
774
     if (analysis->sliceType == X265_TYPE_IDR || analysis->sliceType == X265_TYPE_I)
775
     {
776
@@ -2761,17 +3060,33 @@
777
     }
778
     else
779
     {
780
-        int numDir = analysis->sliceType == X265_TYPE_P ? 1 : 2;
781
         X265_FWRITE(((analysis_inter_data*)analysis->interData)->depth, sizeof(uint8_t), depthBytes, m_analysisFile);
782
         X265_FWRITE(((analysis_inter_data*)analysis->interData)->modes, sizeof(uint8_t), depthBytes, m_analysisFile);
783
-        X265_FWRITE(((analysis_inter_data*)analysis->interData)->partSize, sizeof(uint8_t), depthBytes, m_analysisFile);
784
-        X265_FWRITE(((analysis_inter_data*)analysis->interData)->mergeFlag, sizeof(uint8_t), depthBytes, m_analysisFile);
785
-        X265_FWRITE(((analysis_inter_data*)analysis->interData)->ref, sizeof(int32_t), analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir, m_analysisFile);
786
-        uint32_t numPlanes = m_param->internalCsp == X265_CSP_I400 ? 1 : 3;
787
-        X265_FWRITE(((analysis_inter_data*)analysis->interData)->wt, sizeof(WeightParam), numPlanes * numDir, m_analysisFile);
788
+        if (m_param->analysisRefineLevel > 4)
789
+        {
790
+            X265_FWRITE(((analysis_inter_data*)analysis->interData)->partSize, sizeof(uint8_t), depthBytes, m_analysisFile);
791
+            X265_FWRITE(((analysis_inter_data*)analysis->interData)->mergeFlag, sizeof(uint8_t), depthBytes, m_analysisFile);
792
+            if (m_param->analysisRefineLevel == 10)
793
+            {
794
+                X265_FWRITE(((analysis_inter_data*)analysis->interData)->interDir, sizeof(uint8_t), depthBytes, m_analysisFile);
795
+                if (bIntraInInter) X265_FWRITE(((analysis_intra_data*)analysis->intraData)->chromaModes, sizeof(uint8_t), depthBytes, m_analysisFile);
796
+                for (uint32_t dir = 0; dir < numDir; dir++)
797
+                {
798
+                    X265_FWRITE(((analysis_inter_data*)analysis->interData)->mvpIdx[dir], sizeof(uint8_t), depthBytes, m_analysisFile);
799
+                    X265_FWRITE(((analysis_inter_data*)analysis->interData)->refIdx[dir], sizeof(int8_t), depthBytes, m_analysisFile);
800
+                    X265_FWRITE(((analysis_inter_data*)analysis->interData)->mv[dir], sizeof(MV), depthBytes, m_analysisFile);
801
+                }
802
+                if (bIntraInInter)
803
+                    X265_FWRITE(((analysis_intra_data*)analysis->intraData)->modes, sizeof(uint8_t), analysis->numCUsInFrame * analysis->numPartitions, m_analysisFile);
804
+            }
805
+        }
806
+        if (m_param->analysisRefineLevel != 10)
807
+            X265_FWRITE(((analysis_inter_data*)analysis->interData)->ref, sizeof(int32_t), analysis->numCUsInFrame * X265_MAX_PRED_MODE_PER_CTU * numDir, m_analysisFile);
808
+
809
     }
810
 #undef X265_FWRITE
811
 }
812
+
813
 void Encoder::writeAnalysis2PassFile(x265_analysis_2Pass* analysis2Pass, FrameData &curEncData, int slicetype)
814
 {
815
 #define X265_FWRITE(val, size, writeSize, fileOffset)\
816
@@ -2870,7 +3185,7 @@
817
 
818
 void Encoder::printReconfigureParams()
819
 {
820
-    if (!m_reconfigure)
821
+    if (!(m_reconfigure || m_reconfigureRc))
822
         return;
823
     x265_param* oldParam = m_param;
824
     x265_param* newParam = m_latestParam;
825
@@ -2892,6 +3207,10 @@
826
     TOOLCMP(oldParam->maxNumMergeCand, newParam->maxNumMergeCand, "max-merge=%d to %d\n");
827
     TOOLCMP(oldParam->bIntraInBFrames, newParam->bIntraInBFrames, "b-intra=%d to %d\n");
828
     TOOLCMP(oldParam->scalingLists, newParam->scalingLists, "scalinglists=%s to %s\n");
829
+    TOOLCMP(oldParam->rc.vbvMaxBitrate, newParam->rc.vbvMaxBitrate, "vbv-maxrate=%d to %d\n");
830
+    TOOLCMP(oldParam->rc.vbvBufferSize, newParam->rc.vbvBufferSize, "vbv-bufsize=%d to %d\n");
831
+    TOOLCMP(oldParam->rc.bitrate, newParam->rc.bitrate, "bitrate=%d to %d\n");
832
+    TOOLCMP(oldParam->rc.rfConstant, newParam->rc.rfConstant, "crf=%f to %f\n");
833
 }
834
 
835
 bool Encoder::computeSPSRPSIndex()
836
x265_2.3.tar.gz/source/encoder/encoder.h -> x265_2.4.tar.gz/source/encoder/encoder.h Changed
57
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
@@ -32,8 +32,11 @@
9
 #include "nal.h"
10
 #include "framedata.h"
11
 
12
-struct x265_encoder {};
13
+#ifdef ENABLE_DYNAMIC_HDR10
14
+    #include "dynamicHDR10\hdr10plus.h"
15
+#endif
16
 
17
+struct x265_encoder {};
18
 namespace X265_NS {
19
 // private namespace
20
 extern const char g_sliceTypeToChar[3];
21
@@ -153,6 +156,7 @@
22
     bool               m_bZeroLatency;     // x265_encoder_encode() returns NALs for the input picture, zero lag
23
     bool               m_aborted;          // fatal error detected
24
     bool               m_reconfigure;      // Encoder reconfigure in progress
25
+    bool               m_reconfigureRc;
26
 
27
     /* Begin intra refresh when one not in progress or else begin one as soon as the current 
28
      * one is done. Requires bIntraRefresh to be set.*/
29
@@ -168,9 +172,26 @@
30
 
31
     Lock               m_rpsInSpsLock;
32
     int                m_rpsInSpsCount;
33
+    /* For HDR*/
34
+    double                m_cB;
35
+    double                m_cR;
36
+
37
+    int                     m_bToneMap; // Enables tone-mapping
38
+
39
+#ifdef ENABLE_DYNAMIC_HDR10
40
+    const hdr10plus_api     *m_hdr10plus_api;
41
+#endif
42
+
43
+    x265_sei_payload        m_prevTonemapPayload;
44
 
45
     Encoder();
46
-    ~Encoder() {}
47
+    ~Encoder()
48
+    {
49
+#ifdef ENABLE_DYNAMIC_HDR10
50
+        if (m_prevTonemapPayload.payload != NULL)
51
+            X265_FREE(m_prevTonemapPayload.payload);
52
+#endif
53
+    };
54
 
55
     void create();
56
     void stopJobs();
57
x265_2.3.tar.gz/source/encoder/entropy.cpp -> x265_2.4.tar.gz/source/encoder/entropy.cpp Changed
29
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
@@ -349,7 +349,7 @@
9
 
10
     WRITE_SVLC(pps.chromaQpOffset[0],      "pps_cb_qp_offset");
11
     WRITE_SVLC(pps.chromaQpOffset[1],      "pps_cr_qp_offset");
12
-    WRITE_FLAG(0,                          "pps_slice_chroma_qp_offsets_present_flag");
13
+    WRITE_FLAG(pps.pps_slice_chroma_qp_offsets_present_flag, "pps_slice_chroma_qp_offsets_present_flag");
14
 
15
     WRITE_FLAG(pps.bUseWeightPred,            "weighted_pred_flag");
16
     WRITE_FLAG(pps.bUseWeightedBiPred,        "weighted_bipred_flag");
17
@@ -692,6 +692,11 @@
18
     int code = sliceQp - (slice.m_iPPSQpMinus26 + 26);
19
     WRITE_SVLC(code, "slice_qp_delta");
20
 
21
+    if (slice.m_pps->pps_slice_chroma_qp_offsets_present_flag)
22
+    {
23
+        WRITE_SVLC(slice.m_chromaQpOffset[0], "slice_cb_qp_offset");
24
+        WRITE_SVLC(slice.m_chromaQpOffset[1], "slice_cr_qp_offset");
25
+    }
26
     // TODO: Enable when pps_loop_filter_across_slices_enabled_flag==1
27
     //       We didn't support filter across slice board, so disable it now
28
 
29
x265_2.3.tar.gz/source/encoder/entropy.h -> x265_2.4.tar.gz/source/encoder/entropy.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/frameencoder.cpp -> x265_2.4.tar.gz/source/encoder/frameencoder.cpp Changed
163
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Chung Shin Yee <shinyee@multicorewareinc.com>
7
  *          Min Chen <chenm003@163.com>
8
@@ -384,7 +384,7 @@
9
 
10
     WeightParam* reuseWP = NULL;
11
     if (m_param->analysisMode && (bUseWeightP || bUseWeightB))
12
-        reuseWP = ((analysis_inter_data*)m_frame->m_analysisData.interData)->wt;
13
+        reuseWP = (WeightParam*)m_frame->m_analysisData.wt;
14
 
15
     if (bUseWeightP || bUseWeightB)
16
     {
17
@@ -448,6 +448,40 @@
18
     /* Get the QP for this frame from rate control. This call may block until
19
      * frames ahead of it in encode order have called rateControlEnd() */
20
     m_rce.encodeOrder = m_frame->m_encodeOrder;
21
+    bool payloadChange = false;
22
+    bool writeSei = true;
23
+    if (m_param->bDhdr10opt)
24
+    {
25
+        for (int i = 0; i < m_frame->m_userSEI.numPayloads; i++)
26
+        {
27
+            x265_sei_payload *payload = &m_frame->m_userSEI.payloads[i];
28
+            if(payload->payloadType == USER_DATA_REGISTERED_ITU_T_T35)
29
+            {
30
+                if (m_top->m_prevTonemapPayload.payload != NULL && payload->payloadSize == m_top->m_prevTonemapPayload.payloadSize)
31
+                {
32
+                    if (memcmp(m_top->m_prevTonemapPayload.payload, payload->payload, payload->payloadSize) != 0)
33
+                        payloadChange = true;
34
+                }
35
+                else
36
+                {
37
+                    payloadChange = true;
38
+                    if (m_top->m_prevTonemapPayload.payload != NULL)
39
+                        x265_free(m_top->m_prevTonemapPayload.payload);
40
+                    m_top->m_prevTonemapPayload.payload = (uint8_t*)x265_malloc(sizeof(uint8_t) * payload->payloadSize);
41
+                }
42
+
43
+                if (payloadChange)
44
+                {
45
+                    m_top->m_prevTonemapPayload.payloadType = payload->payloadType;
46
+                    m_top->m_prevTonemapPayload.payloadSize = payload->payloadSize;
47
+                    memcpy(m_top->m_prevTonemapPayload.payload, payload->payload, payload->payloadSize);
48
+                }
49
+
50
+                bool isIDR = m_frame->m_lowres.sliceType == X265_TYPE_IDR;
51
+                writeSei = payloadChange || isIDR;
52
+            }
53
+        }
54
+    }
55
     int qp = m_top->m_rateControl->rateControlStart(m_frame, &m_rce, m_top);
56
     m_rce.newQp = qp;
57
 
58
@@ -483,6 +517,13 @@
59
 
60
     /* Clip slice QP to 0-51 spec range before encoding */
61
     slice->m_sliceQp = x265_clip3(-QP_BD_OFFSET, QP_MAX_SPEC, qp);
62
+    if (m_param->bHDROpt)
63
+    {
64
+        int qpCb = x265_clip3(-12, 0, (int)floor((m_top->m_cB * ((-.46) * qp + 9.26)) + 0.5 ));
65
+        int qpCr = x265_clip3(-12, 0, (int)floor((m_top->m_cR * ((-.46) * qp + 9.26)) + 0.5 ));
66
+        slice->m_chromaQpOffset[0] = slice->m_pps->chromaQpOffset[0] + qpCb < -12 ? (qpCb + (-12 - (slice->m_pps->chromaQpOffset[0] + qpCb))) : qpCb;
67
+        slice->m_chromaQpOffset[1] = slice->m_pps->chromaQpOffset[1] + qpCr < -12 ? (qpCr + (-12 - (slice->m_pps->chromaQpOffset[1] + qpCr))) : qpCr;
68
+    }
69
 
70
     if (m_param->bOptQpPPS && m_param->bRepeatHeaders)
71
     {
72
@@ -608,18 +649,32 @@
73
     for (int i = 0; i < m_frame->m_userSEI.numPayloads; i++)
74
     {
75
         x265_sei_payload *payload = &m_frame->m_userSEI.payloads[i];
76
-        SEIuserDataUnregistered sei;
77
-
78
-        sei.m_payloadType = payload->payloadType;
79
-        sei.m_userDataLength = payload->payloadSize;
80
-        sei.m_userData = payload->payload;
81
-
82
-        m_bs.resetBits();
83
-        sei.write(m_bs, *slice->m_sps);
84
-        m_bs.writeByteAlignment();
85
-        m_nalList.serialize(NAL_UNIT_PREFIX_SEI, m_bs);
86
+        if (payload->payloadType == USER_DATA_UNREGISTERED)
87
+        {
88
+            SEIuserDataUnregistered sei;
89
+            sei.m_userData = payload->payload;
90
+            m_bs.resetBits();
91
+            sei.setSize(payload->payloadSize);
92
+            sei.write(m_bs, *slice->m_sps);
93
+            m_bs.writeByteAlignment();
94
+            m_nalList.serialize(NAL_UNIT_PREFIX_SEI, m_bs);
95
+        }
96
+        else if (payload->payloadType == USER_DATA_REGISTERED_ITU_T_T35)
97
+        {
98
+            if (writeSei)
99
+            {
100
+                SEICreativeIntentMeta sei;
101
+                sei.cim = payload->payload;
102
+                m_bs.resetBits();
103
+                sei.setSize(payload->payloadSize);
104
+                sei.write(m_bs, *slice->m_sps);
105
+                m_bs.writeByteAlignment();
106
+                m_nalList.serialize(NAL_UNIT_PREFIX_SEI, m_bs);
107
+            }
108
+        }
109
+        else
110
+            x265_log(m_param, X265_LOG_ERROR, "Unrecognized SEI type\n");
111
     }
112
-
113
     /* CQP and CRF (without capped VBV) doesn't use mid-frame statistics to 
114
      * tune RateControl parameters for other frames.
115
      * Hence, for these modes, update m_startEndOrder and unlock RC for previous threads waiting in
116
@@ -928,29 +983,32 @@
117
     if (m_param->decodedPictureHashSEI)
118
     {
119
         int planes = (m_frame->m_param->internalCsp != X265_CSP_I400) ? 3 : 1;
120
+        int32_t payloadSize = 0;
121
         if (m_param->decodedPictureHashSEI == 1)
122
         {
123
             m_seiReconPictureDigest.m_method = SEIDecodedPictureHash::MD5;
124
             for (int i = 0; i < planes; i++)
125
                 MD5Final(&m_state[i], m_seiReconPictureDigest.m_digest[i]);
126
+            payloadSize = 1 + 16 * planes;
127
         }
128
         else if (m_param->decodedPictureHashSEI == 2)
129
         {
130
             m_seiReconPictureDigest.m_method = SEIDecodedPictureHash::CRC;
131
             for (int i = 0; i < planes; i++)
132
                 crcFinish(m_crc[i], m_seiReconPictureDigest.m_digest[i]);
133
+            payloadSize = 1 + 2 * planes;
134
         }
135
         else if (m_param->decodedPictureHashSEI == 3)
136
         {
137
             m_seiReconPictureDigest.m_method = SEIDecodedPictureHash::CHECKSUM;
138
             for (int i = 0; i < planes; i++)
139
                 checksumFinish(m_checksum[i], m_seiReconPictureDigest.m_digest[i]);
140
+            payloadSize = 1 + 4 * planes;
141
         }
142
-
143
         m_bs.resetBits();
144
+        m_seiReconPictureDigest.setSize(payloadSize);
145
         m_seiReconPictureDigest.write(m_bs, *slice->m_sps);
146
         m_bs.writeByteAlignment();
147
-
148
         m_nalList.serialize(NAL_UNIT_SUFFIX_SEI, m_bs);
149
     }
150
 
151
@@ -1328,11 +1386,6 @@
152
             rowCoder.copyState(m_initSliceContext);
153
             rowCoder.loadContexts(m_rows[row - 1].bufferedEntropy);
154
         }
155
-        analysis2PassFrameData* analysisFrameData = (analysis2PassFrameData*)(m_frame->m_analysis2Pass).analysisFramedata;
156
-        if (analysisFrameData && m_param->rc.bStatRead && m_param->analysisMultiPassDistortion && (analysisFrameData->threshold[cuAddr] < 0.9 || analysisFrameData->threshold[cuAddr] > 1.1)
157
-            && analysisFrameData->highDistortionCtuCount && analysisFrameData->lowDistortionCtuCount)
158
-            curEncData.m_cuStat[cuAddr].baseQp += analysisFrameData->offset[cuAddr];
159
-
160
         if (m_param->dynamicRd && (int32_t)(m_rce.qpaRc - m_rce.qpNoVbv) > 0)
161
             ctu->m_vbvAffected = true;
162
 
163
x265_2.3.tar.gz/source/encoder/frameencoder.h -> x265_2.4.tar.gz/source/encoder/frameencoder.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Shin Yee <shinyee@multicorewareinc.com>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/framefilter.cpp -> x265_2.4.tar.gz/source/encoder/framefilter.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Chung Shin Yee <shinyee@multicorewareinc.com>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/framefilter.h -> x265_2.4.tar.gz/source/encoder/framefilter.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Chung Shin Yee <shinyee@multicorewareinc.com>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/level.cpp -> x265_2.4.tar.gz/source/encoder/level.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/level.h -> x265_2.4.tar.gz/source/encoder/level.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/encoder/motion.cpp -> x265_2.4.tar.gz/source/encoder/motion.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/motion.h -> x265_2.4.tar.gz/source/encoder/motion.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/nal.cpp -> x265_2.4.tar.gz/source/encoder/nal.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/nal.h -> x265_2.4.tar.gz/source/encoder/nal.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *
8
x265_2.3.tar.gz/source/encoder/ratecontrol.cpp -> x265_2.4.tar.gz/source/encoder/ratecontrol.cpp Changed
152
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Sumalatha Polureddy <sumalatha@multicorewareinc.com>
7
  *          Aarthi Priya Thirumalai <aarthi@multicorewareinc.com>
8
@@ -683,6 +683,56 @@
9
     return true;
10
 }
11
 
12
+void RateControl::reconfigureRC()
13
+{
14
+    if (m_isVbv)
15
+    {
16
+        m_param->rc.vbvBufferSize = x265_clip3(0, 2000000, m_param->rc.vbvBufferSize);
17
+        m_param->rc.vbvMaxBitrate = x265_clip3(0, 2000000, m_param->rc.vbvMaxBitrate);
18
+        if (m_param->rc.vbvMaxBitrate < m_param->rc.bitrate &&
19
+            m_param->rc.rateControlMode == X265_RC_ABR)
20
+        {
21
+            x265_log(m_param, X265_LOG_WARNING, "max bitrate less than average bitrate, assuming CBR\n");
22
+            m_param->rc.bitrate = m_param->rc.vbvMaxBitrate;
23
+        }
24
+
25
+        if (m_param->rc.vbvBufferSize < (int)(m_param->rc.vbvMaxBitrate / m_fps))
26
+        {
27
+            m_param->rc.vbvBufferSize = (int)(m_param->rc.vbvMaxBitrate / m_fps);
28
+            x265_log(m_param, X265_LOG_WARNING, "VBV buffer size cannot be smaller than one frame, using %d kbit\n",
29
+                m_param->rc.vbvBufferSize);
30
+        }
31
+        int vbvBufferSize = m_param->rc.vbvBufferSize * 1000;
32
+        int vbvMaxBitrate = m_param->rc.vbvMaxBitrate * 1000;
33
+        m_bufferRate = vbvMaxBitrate / m_fps;
34
+        m_vbvMaxRate = vbvMaxBitrate;
35
+        m_bufferSize = vbvBufferSize;
36
+        m_singleFrameVbv = m_bufferRate * 1.1 > m_bufferSize;
37
+    }
38
+    if (m_param->rc.rateControlMode == X265_RC_CRF)
39
+    {
40
+        #define CRF_INIT_QP (int)m_param->rc.rfConstant
41
+        m_param->rc.bitrate = 0;
42
+        double baseCplx = m_ncu * (m_param->bframes ? 120 : 80);
43
+        double mbtree_offset = m_param->rc.cuTree ? (1.0 - m_param->rc.qCompress) * 13.5 : 0;
44
+        m_rateFactorConstant = pow(baseCplx, 1 - m_qCompress) /
45
+            x265_qp2qScale(m_param->rc.rfConstant + mbtree_offset);
46
+        if (m_param->rc.rfConstantMax)
47
+        {
48
+            m_rateFactorMaxIncrement = m_param->rc.rfConstantMax - m_param->rc.rfConstant;
49
+            if (m_rateFactorMaxIncrement <= 0)
50
+            {
51
+                x265_log(m_param, X265_LOG_WARNING, "CRF max must be greater than CRF\n");
52
+                m_rateFactorMaxIncrement = 0;
53
+            }
54
+        }
55
+        if (m_param->rc.rfConstantMin)
56
+            m_rateFactorMaxDecrement = m_param->rc.rfConstant - m_param->rc.rfConstantMin;
57
+    }
58
+    m_bitrate = m_param->rc.bitrate * 1000;
59
+}
60
+
61
+
62
 void RateControl::initHRD(SPS& sps)
63
 {
64
     int vbvBufferSize = m_param->rc.vbvBufferSize * 1000;
65
@@ -1298,6 +1348,8 @@
66
         curFrame->m_rcData->cumulativePNorm = m_accumPNorm;
67
         for (int i = 0; i < 3; i++)
68
             curFrame->m_rcData->lastQScaleFor[i] = m_lastQScaleFor[i];
69
+        curFrame->m_rcData->shortTermCplxSum = m_shortTermCplxSum;
70
+        curFrame->m_rcData->shortTermCplxCount = m_shortTermCplxCount;
71
     }
72
     else // CQP
73
     {
74
@@ -1896,20 +1948,20 @@
75
             else if (m_framesDone == 0 && !m_isVbv && m_param->rc.rateControlMode == X265_RC_ABR)
76
             {
77
                 /* for ABR alone, clip the first I frame qp */
78
-                    lqmax =  (m_lstep * m_isGrainEnabled) ? x265_qp2qScale(ABR_INIT_QP_GRAIN_MAX) :
79
+                lqmax = (m_isGrainEnabled && m_lstep) ? x265_qp2qScale(ABR_INIT_QP_GRAIN_MAX) :
80
                         x265_qp2qScale(ABR_INIT_QP_MAX);
81
-                    q = X265_MIN(lqmax, q);
82
+                q = X265_MIN(lqmax, q);
83
             }
84
             q = x265_clip3(lqmin, lqmax, q);
85
             /* Set a min qp at scenechanges and transitions */
86
             if (m_isSceneTransition)
87
             {
88
-               double minScenecutQscale =x265_qp2qScale(ABR_SCENECUT_INIT_QP_MIN); 
89
-               q = X265_MAX(minScenecutQscale, q);
90
-               m_lastQScaleFor[P_SLICE] = X265_MAX(minScenecutQscale, m_lastQScaleFor[P_SLICE]);
91
+                double minScenecutQscale = x265_qp2qScale(ABR_SCENECUT_INIT_QP_MIN);
92
+                q = X265_MAX(minScenecutQscale, q);
93
+                m_lastQScaleFor[P_SLICE] = X265_MAX(minScenecutQscale, m_lastQScaleFor[P_SLICE]);
94
             }
95
             rce->qpNoVbv = x265_qScale2qp(q);
96
-            if(m_sliceType == P_SLICE)
97
+            if (m_sliceType == P_SLICE)
98
             {
99
                 m_avgPFrameQp = m_avgPFrameQp == 0 ? rce->qpNoVbv : m_avgPFrameQp;
100
                 m_avgPFrameQp = (m_avgPFrameQp + rce->qpNoVbv) / 2;
101
@@ -2498,25 +2550,25 @@
102
     m_bufferFillFinal = X265_MAX(m_bufferFillFinal, 0);
103
     m_bufferFillFinal += m_bufferRate;
104
 
105
-    if (m_bufferFillFinal > m_bufferSize) 
106
+    if (m_param->rc.bStrictCbr)
107
     {
108
-        if (m_param->rc.bStrictCbr)
109
+        if (m_bufferFillFinal > m_bufferSize)
110
         {
111
             filler = (int)(m_bufferFillFinal - m_bufferSize);
112
             filler += FILLER_OVERHEAD * 8;
113
-            m_bufferFillFinal -= filler;
114
-            bufferBits = X265_MIN(bits + filler + m_bufferExcess, m_bufferRate);
115
-            m_bufferExcess = X265_MAX(m_bufferExcess - bufferBits + bits + filler, 0);
116
-            m_bufferFillActual += bufferBits - bits - filler;
117
-        }
118
-        else
119
-        {
120
-            m_bufferFillFinal = X265_MIN(m_bufferFillFinal, m_bufferSize);
121
-            bufferBits = X265_MIN(bits + m_bufferExcess, m_bufferRate);
122
-            m_bufferExcess = X265_MAX(m_bufferExcess - bufferBits + bits, 0);
123
-            m_bufferFillActual += bufferBits - bits;
124
-            m_bufferFillActual = X265_MIN(m_bufferFillActual, m_bufferSize);
125
         }
126
+        m_bufferFillFinal -= filler;
127
+        bufferBits = X265_MIN(bits + filler + m_bufferExcess, m_bufferRate);
128
+        m_bufferExcess = X265_MAX(m_bufferExcess - bufferBits + bits + filler, 0);
129
+        m_bufferFillActual += bufferBits - bits - filler;
130
+    }
131
+    else
132
+    {
133
+        m_bufferFillFinal = X265_MIN(m_bufferFillFinal, m_bufferSize);
134
+        bufferBits = X265_MIN(bits + m_bufferExcess, m_bufferRate);
135
+        m_bufferExcess = X265_MAX(m_bufferExcess - bufferBits + bits, 0);
136
+        m_bufferFillActual += bufferBits - bits;
137
+        m_bufferFillActual = X265_MIN(m_bufferFillActual, m_bufferSize);
138
     }
139
     return filler;
140
 }
141
@@ -2643,6 +2695,10 @@
142
         int qp = int (rce->qpaRc + 0.5);
143
         m_qpToEncodedBits[qp] =  m_qpToEncodedBits[qp] == 0 ? actualBits : (m_qpToEncodedBits[qp] + actualBits) * 0.5;
144
         }
145
+        curFrame->m_rcData->wantedBitsWindow = m_wantedBitsWindow;
146
+        curFrame->m_rcData->cplxrSum = m_cplxrSum;
147
+        curFrame->m_rcData->totalBits = m_totalBits;
148
+        curFrame->m_rcData->encodedBits = m_encodedBits;
149
     }
150
 
151
     if (m_2pass)
152
x265_2.3.tar.gz/source/encoder/ratecontrol.h -> x265_2.4.tar.gz/source/encoder/ratecontrol.h Changed
16
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Sumalatha Polureddy <sumalatha@multicorewareinc.com>
7
  *          Aarthi Priya Thirumalai <aarthi@multicorewareinc.com>
8
@@ -234,6 +234,7 @@
9
     RateControl(x265_param& p);
10
     bool init(const SPS& sps);
11
     void initHRD(SPS& sps);
12
+    void reconfigureRC();
13
 
14
     void setFinalFrameCount(int count);
15
     void terminate();          /* un-block all waiting functions so encoder may close */
16
x265_2.3.tar.gz/source/encoder/rdcost.h -> x265_2.4.tar.gz/source/encoder/rdcost.h Changed
26
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
@@ -67,13 +67,13 @@
9
         int qpCb, qpCr;
10
         if (slice.m_sps->chromaFormatIdc == X265_CSP_I420)
11
         {
12
-            qpCb = (int)g_chromaScale[x265_clip3(QP_MIN, QP_MAX_MAX, qp + slice.m_pps->chromaQpOffset[0])];
13
-            qpCr = (int)g_chromaScale[x265_clip3(QP_MIN, QP_MAX_MAX, qp + slice.m_pps->chromaQpOffset[1])];
14
+            qpCb = (int)g_chromaScale[x265_clip3(QP_MIN, QP_MAX_MAX, qp + slice.m_pps->chromaQpOffset[0] + slice.m_chromaQpOffset[0])];
15
+            qpCr = (int)g_chromaScale[x265_clip3(QP_MIN, QP_MAX_MAX, qp + slice.m_pps->chromaQpOffset[1] + slice.m_chromaQpOffset[1])];
16
         }
17
         else
18
         {
19
-            qpCb = x265_clip3(QP_MIN, QP_MAX_SPEC, qp + slice.m_pps->chromaQpOffset[0]);
20
-            qpCr = x265_clip3(QP_MIN, QP_MAX_SPEC, qp + slice.m_pps->chromaQpOffset[1]);
21
+            qpCb = x265_clip3(QP_MIN, QP_MAX_SPEC, qp + slice.m_pps->chromaQpOffset[0] + slice.m_chromaQpOffset[0]);
22
+            qpCr = x265_clip3(QP_MIN, QP_MAX_SPEC, qp + slice.m_pps->chromaQpOffset[1] + slice.m_chromaQpOffset[1]);
23
         }
24
 
25
         if (slice.m_sps->chromaFormatIdc == X265_CSP_I444)
26
x265_2.3.tar.gz/source/encoder/reference.cpp -> x265_2.4.tar.gz/source/encoder/reference.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Deepthi Devaki <deepthidevaki@multicorewareinc.com>
8
x265_2.3.tar.gz/source/encoder/reference.h -> x265_2.4.tar.gz/source/encoder/reference.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/sao.cpp -> x265_2.4.tar.gz/source/encoder/sao.cpp Changed
336
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -734,6 +734,7 @@
9
 /* Calculate SAO statistics for current CTU without non-crossing slice */
10
 void SAO::calcSaoStatsCTU(int addr, int plane)
11
 {
12
+    Slice* slice = m_frame->m_encData->m_slice;
13
     const PicYuv* reconPic = m_frame->m_reconPic;
14
     const CUData* cu = m_frame->m_encData->getPicCTU(addr);
15
     const pixel* fenc0 = m_frame->m_fencPic->getPlaneAddr(plane, addr);
16
@@ -857,60 +858,60 @@
17
 
18
             primitives.saoCuStatsE1(diff + startY * MAX_CU_SIZE, rec0 + startY * stride, stride, upBuff1, endX, endY - startY, m_offsetOrg[plane][SAO_EO_1], m_count[plane][SAO_EO_1]);
19
         }
20
-
21
-        // SAO_EO_2: // dir: 135
22
+        if (!m_param->bLimitSAO || ((slice->m_sliceType == P_SLICE && !cu->isSkipped(0)) ||
23
+            (slice->m_sliceType != B_SLICE)))
24
         {
25
-            if (m_param->bSaoNonDeblocked)
26
+            // SAO_EO_2: // dir: 135
27
             {
28
-                skipB = 4;
29
-                skipR = 5;
30
-            }
31
+                if (m_param->bSaoNonDeblocked)
32
+                {
33
+                    skipB = 4;
34
+                    skipR = 5;
35
+                }
36
 
37
-            fenc = fenc0;
38
-            rec  = rec0;
39
+                fenc = fenc0;
40
+                rec  = rec0;
41
 
42
-            startX = !lpelx;
43
-            endX   = (rpelx == picWidth) ? ctuWidth - 1 : ctuWidth - skipR + plane_offset;
44
+                startX = !lpelx;
45
+                endX   = (rpelx == picWidth) ? ctuWidth - 1 : ctuWidth - skipR + plane_offset;
46
 
47
-            startY = bAboveUnavail;
48
-            endY   = (bpely == picHeight) ? ctuHeight - 1 : ctuHeight - skipB + plane_offset;
49
-            if (startY)
50
-            {
51
-                fenc += stride;
52
-                rec += stride;
53
-            }
54
-
55
-            primitives.sign(upBuff1, &rec[startX], &rec[startX - stride - 1], (endX - startX));
56
+                startY = bAboveUnavail;
57
+                endY   = (bpely == picHeight) ? ctuHeight - 1 : ctuHeight - skipB + plane_offset;
58
+                if (startY)
59
+                {
60
+                    fenc += stride;
61
+                    rec += stride;
62
+                }
63
 
64
-            primitives.saoCuStatsE2(diff + startX + startY * MAX_CU_SIZE, rec0  + startX + startY * stride, stride, upBuff1, upBufft, endX - startX, endY - startY, m_offsetOrg[plane][SAO_EO_2], m_count[plane][SAO_EO_2]);
65
-        }
66
+                primitives.sign(upBuff1, &rec[startX], &rec[startX - stride - 1], (endX - startX));
67
 
68
-        // SAO_EO_3: // dir: 45
69
-        {
70
-            if (m_param->bSaoNonDeblocked)
71
-            {
72
-                skipB = 4;
73
-                skipR = 5;
74
+                primitives.saoCuStatsE2(diff + startX + startY * MAX_CU_SIZE, rec0  + startX + startY * stride, stride, upBuff1, upBufft, endX - startX, endY - startY, m_offsetOrg[plane][SAO_EO_2], m_count[plane][SAO_EO_2]);
75
             }
76
+            // SAO_EO_3: // dir: 45
77
+            {
78
+                if (m_param->bSaoNonDeblocked)
79
+                {
80
+                    skipB = 4;
81
+                    skipR = 5;
82
+                }
83
+                fenc = fenc0;
84
+                rec  = rec0;
85
+                startX = !lpelx;
86
+                endX   = (rpelx == picWidth) ? ctuWidth - 1 : ctuWidth - skipR + plane_offset;
87
 
88
-            fenc = fenc0;
89
-            rec  = rec0;
90
+                startY = bAboveUnavail;
91
+                endY   = (bpely == picHeight) ? ctuHeight - 1 : ctuHeight - skipB + plane_offset;
92
 
93
-            startX = !lpelx;
94
-            endX   = (rpelx == picWidth) ? ctuWidth - 1 : ctuWidth - skipR + plane_offset;
95
+                if (startY)
96
+                {
97
+                    fenc += stride;
98
+                    rec += stride;
99
+                }
100
 
101
-            startY = bAboveUnavail;
102
-            endY   = (bpely == picHeight) ? ctuHeight - 1 : ctuHeight - skipB + plane_offset;
103
+                primitives.sign(upBuff1, &rec[startX - 1], &rec[startX - 1 - stride + 1], (endX - startX + 1));
104
 
105
-            if (startY)
106
-            {
107
-                fenc += stride;
108
-                rec += stride;
109
+                primitives.saoCuStatsE3(diff + startX + startY * MAX_CU_SIZE, rec0  + startX + startY * stride, stride, upBuff1 + 1, endX - startX, endY - startY, m_offsetOrg[plane][SAO_EO_3], m_count[plane][SAO_EO_3]);
110
             }
111
-
112
-            primitives.sign(upBuff1, &rec[startX - 1], &rec[startX - 1 - stride + 1], (endX - startX + 1));
113
-
114
-            primitives.saoCuStatsE3(diff + startX + startY * MAX_CU_SIZE, rec0  + startX + startY * stride, stride, upBuff1 + 1, endX - startX, endY - startY, m_offsetOrg[plane][SAO_EO_3], m_count[plane][SAO_EO_3]);
115
         }
116
     }
117
 }
118
@@ -1224,18 +1225,15 @@
119
 void SAO::rdoSaoUnitCu(SAOParam* saoParam, int rowBaseAddr, int idxX, int addr)
120
 {
121
     Slice* slice = m_frame->m_encData->m_slice;
122
-//    int qp = slice->m_sliceQp;
123
     const CUData* cu = m_frame->m_encData->getPicCTU(addr);
124
     int qp = cu->m_qp[0];
125
-
126
     int64_t lambda[2] = { 0 };
127
 
128
-    int qpCb = qp;
129
+    int qpCb = qp + slice->m_pps->chromaQpOffset[0] + slice->m_chromaQpOffset[0];
130
     if (m_param->internalCsp == X265_CSP_I420)
131
-        qpCb = x265_clip3(m_param->rc.qpMin, m_param->rc.qpMax, (int)g_chromaScale[qp + slice->m_pps->chromaQpOffset[0]]);
132
+        qpCb = x265_clip3(m_param->rc.qpMin, m_param->rc.qpMax, (int)g_chromaScale[x265_clip3(QP_MIN, QP_MAX_MAX, qpCb)]);
133
     else
134
-        qpCb = X265_MIN(qp + slice->m_pps->chromaQpOffset[0], QP_MAX_SPEC);
135
-
136
+        qpCb = x265_clip3(m_param->rc.qpMin, m_param->rc.qpMax, qpCb);
137
     lambda[0] = (int64_t)floor(256.0 * x265_lambda2_tab[qp]);
138
     lambda[1] = (int64_t)floor(256.0 * x265_lambda2_tab[qpCb]); // Use Cb QP for SAO chroma
139
 
140
@@ -1263,18 +1261,6 @@
141
 
142
     for (int i = 0; i < planes; i++)
143
         saoParam->ctuParam[i][addr].reset();
144
-
145
-    if (saoParam->bSaoFlag[0])
146
-        calcSaoStatsCTU(addr, 0);
147
-
148
-    if (saoParam->bSaoFlag[1])
149
-    {
150
-        calcSaoStatsCTU(addr, 1);
151
-        calcSaoStatsCTU(addr, 2);
152
-    }
153
-
154
-    saoStatsInitialOffset(planes);
155
-
156
     // SAO distortion calculation
157
     m_entropyCoder.load(m_rdContexts.cur);
158
     m_entropyCoder.resetBits();
159
@@ -1283,15 +1269,44 @@
160
     if (allowMerge[1])
161
         m_entropyCoder.codeSaoMerge(0);
162
     m_entropyCoder.store(m_rdContexts.temp);
163
-
164
-    // Estimate distortion and cost of new SAO params
165
+    memset(m_offset, 0, sizeof(m_offset));
166
     int64_t bestCost = 0;
167
     int64_t rateDist = 0;
168
+
169
+    bool bAboveLeftAvail = true;
170
+    for (int mergeIdx = 0; mergeIdx < 2; ++mergeIdx)
171
+    {
172
+        if (!allowMerge[mergeIdx])
173
+            continue;
174
+
175
+        SaoCtuParam* mergeSrcParam = &(saoParam->ctuParam[0][addrMerge[mergeIdx]]);
176
+        bAboveLeftAvail = bAboveLeftAvail && (mergeSrcParam->typeIdx == -1);
177
+    }
178
+    // Don't apply sao if ctu is skipped or ajacent ctus are sao off
179
+    bool bSaoOff = (slice->m_sliceType == B_SLICE) && (cu->isSkipped(0) || bAboveLeftAvail);
180
+
181
     // Estimate distortion and cost of new SAO params
182
-    saoLumaComponentParamDist(saoParam, addr, rateDist, lambda, bestCost);
183
-    if (chroma)
184
-        saoChromaComponentParamDist(saoParam, addr, rateDist, lambda, bestCost);
185
+    if (saoParam->bSaoFlag[0])
186
+    {
187
+        if (!m_param->bLimitSAO || !bSaoOff)
188
+        {
189
+            calcSaoStatsCTU(addr, 0);
190
+            saoStatsInitialOffset(addr, 0);
191
+            saoLumaComponentParamDist(saoParam, addr, rateDist, lambda, bestCost);
192
+        }
193
+    }
194
 
195
+    SaoCtuParam* lclCtuParam = &saoParam->ctuParam[0][addr];
196
+    if (saoParam->bSaoFlag[1])
197
+    {
198
+        if (!m_param->bLimitSAO || ((lclCtuParam->typeIdx != -1) && !bSaoOff))
199
+        {
200
+            calcSaoStatsCTU(addr, 1);
201
+            calcSaoStatsCTU(addr, 2);
202
+            saoStatsInitialOffset(addr, 1);
203
+            saoChromaComponentParamDist(saoParam, addr, rateDist, lambda, bestCost);
204
+        }
205
+    }
206
     if (saoParam->bSaoFlag[0] || saoParam->bSaoFlag[1])
207
     {
208
         // Cost of merge left or Up
209
@@ -1358,17 +1373,27 @@
210
     }
211
 }
212
 
213
-
214
 // Rounds the division of initial offsets by the number of samples in
215
 // each of the statistics table entries.
216
-void SAO::saoStatsInitialOffset(int planes)
217
+void SAO::saoStatsInitialOffset(int addr, int planes)
218
 {
219
-    memset(m_offset, 0, sizeof(m_offset));
220
+    Slice* slice = m_frame->m_encData->m_slice;
221
+    const CUData* cu = m_frame->m_encData->getPicCTU(addr);
222
 
223
+    int maxSaoType;
224
+    if (m_param->bLimitSAO && ((slice->m_sliceType == P_SLICE && cu->isSkipped(0)) ||
225
+       (slice->m_sliceType == B_SLICE)))
226
+    {
227
+        maxSaoType = MAX_NUM_SAO_TYPE - 3;
228
+    }
229
+    else
230
+    {
231
+        maxSaoType = MAX_NUM_SAO_TYPE - 1;
232
+    }
233
     // EO
234
-    for (int plane = 0; plane < planes; plane++)
235
+    for (int plane = planes; plane <= planes * 2; plane++)
236
     {
237
-        for (int typeIdx = 0; typeIdx < MAX_NUM_SAO_TYPE - 1; typeIdx++)
238
+        for (int typeIdx = 0; typeIdx < maxSaoType; typeIdx++)
239
         {
240
             for (int classIdx = 1; classIdx < SAO_NUM_OFFSET + 1; classIdx++)
241
             {
242
@@ -1389,9 +1414,8 @@
243
             }
244
         }
245
     }
246
-
247
     // BO
248
-    for (int plane = 0; plane < planes; plane++)
249
+    for (int plane = planes; plane <= planes * 2; plane++)
250
     {
251
         for (int classIdx = 0; classIdx < MAX_NUM_SAO_CLASS; classIdx++)
252
         {
253
@@ -1452,12 +1476,12 @@
254
     costClasses = bestCost;
255
     offset = bestOffset;
256
 }
257
-
258
 void SAO::saoLumaComponentParamDist(SAOParam* saoParam, int32_t addr, int64_t& rateDist, int64_t* lambda, int64_t &bestCost)
259
 {
260
+    Slice* slice = m_frame->m_encData->m_slice;
261
+    const CUData* cu = m_frame->m_encData->getPicCTU(addr);
262
     int64_t bestDist = 0;
263
     int bestTypeIdx = -1;
264
-
265
     SaoCtuParam* lclCtuParam = &saoParam->ctuParam[0][addr];
266
 
267
     int32_t distClasses[MAX_NUM_SAO_CLASS];
268
@@ -1467,19 +1491,27 @@
269
     m_entropyCoder.load(m_rdContexts.temp);
270
     m_entropyCoder.resetBits();
271
     m_entropyCoder.codeSaoType(0);
272
-
273
     int64_t costPartBest = calcSaoRdoCost(0, m_entropyCoder.getNumberOfWrittenBits(), lambda[0]);
274
+    int maxSaoType;
275
+    if (m_param->bLimitSAO && ((slice->m_sliceType == P_SLICE && cu->isSkipped(0)) ||
276
+        (slice->m_sliceType == B_SLICE)))
277
+    {
278
+        maxSaoType = MAX_NUM_SAO_TYPE - 3;
279
+    }
280
+    else
281
+    {
282
+        maxSaoType = MAX_NUM_SAO_TYPE - 1;
283
+    }
284
 
285
     //EO distortion calculation
286
-    for (int typeIdx = 0; typeIdx < MAX_NUM_SAO_TYPE - 1; typeIdx++)
287
+    for (int typeIdx = 0; typeIdx < maxSaoType; typeIdx++)
288
     {
289
         int64_t estDist = 0;
290
         for (int classIdx = 1; classIdx < SAO_NUM_OFFSET + 1; classIdx++)
291
         {
292
-            int32_t&  count     = m_count[0][typeIdx][classIdx];
293
+            int32_t&  count    = m_count[0][typeIdx][classIdx];
294
             int32_t& offsetOrg = m_offsetOrg[0][typeIdx][classIdx];
295
             int32_t& offsetOut = m_offset[0][typeIdx][classIdx];
296
-
297
             estIterOffset(typeIdx, lambda[0], count, offsetOrg, offsetOut, distClasses[classIdx], costClasses[classIdx]);
298
 
299
             //Calculate distortion
300
@@ -1569,12 +1601,12 @@
301
         bestCost = rateDist + m_entropyCoder.getNumberOfWrittenBits();
302
     }
303
 }
304
-
305
 void SAO::saoChromaComponentParamDist(SAOParam* saoParam, int32_t addr, int64_t& rateDist, int64_t* lambda, int64_t &bestCost)
306
 {
307
+    Slice* slice = m_frame->m_encData->m_slice;
308
+    const CUData* cu = m_frame->m_encData->getPicCTU(addr);
309
     int64_t bestDist = 0;
310
     int bestTypeIdx = -1;
311
-
312
     SaoCtuParam* lclCtuParam[2] = { &saoParam->ctuParam[1][addr], &saoParam->ctuParam[2][addr] };
313
 
314
     int64_t costClasses[MAX_NUM_SAO_CLASS];
315
@@ -1587,9 +1619,19 @@
316
 
317
     uint32_t bits = m_entropyCoder.getNumberOfWrittenBits();
318
     int64_t costPartBest = calcSaoRdoCost(0, bits, lambda[1]);
319
+    int maxSaoType;
320
+    if (m_param->bLimitSAO && ((slice->m_sliceType == P_SLICE && cu->isSkipped(0)) ||
321
+        (slice->m_sliceType == B_SLICE)))
322
+    {
323
+        maxSaoType = MAX_NUM_SAO_TYPE - 3;
324
+    }
325
+    else
326
+    {
327
+        maxSaoType = MAX_NUM_SAO_TYPE - 1;
328
+    }
329
 
330
     //EO RDO
331
-    for (int typeIdx = 0; typeIdx < MAX_NUM_SAO_TYPE - 1; typeIdx++)
332
+    for (int typeIdx = 0; typeIdx < maxSaoType; typeIdx++)
333
     {
334
         int64_t estDist[2] = {0, 0};
335
         for (int compIdx = 1; compIdx < 3; compIdx++)
336
x265_2.3.tar.gz/source/encoder/sao.h -> x265_2.4.tar.gz/source/encoder/sao.h Changed
19
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -133,9 +133,7 @@
9
     void rdoSaoUnitRowEnd(const SAOParam* saoParam, int numctus);
10
     void rdoSaoUnitCu(SAOParam* saoParam, int rowBaseAddr, int idxX, int addr);
11
     int64_t calcSaoRdoCost(int64_t distortion, uint32_t bits, int64_t lambda);
12
-
13
-    void saoStatsInitialOffset(int planes);
14
-
15
+    void saoStatsInitialOffset(int addr, int planes);
16
     friend class FrameFilter;
17
 };
18
 
19
x265_2.3.tar.gz/source/encoder/search.cpp -> x265_2.4.tar.gz/source/encoder/search.cpp Changed
18
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
@@ -2150,7 +2150,8 @@
9
         cu.getNeighbourMV(puIdx, pu.puAbsPartIdx, interMode.interNeighbours);
10
 
11
         /* Uni-directional prediction */
12
-        if (m_param->analysisMode == X265_ANALYSIS_LOAD || (m_param->analysisMultiPassRefine && m_param->rc.bStatRead))
13
+        if ((m_param->analysisMode == X265_ANALYSIS_LOAD && m_param->analysisRefineLevel > 1)
14
+            || (m_param->analysisMultiPassRefine && m_param->rc.bStatRead))
15
         {
16
             for (int list = 0; list < numPredDir; list++)
17
             {
18
x265_2.3.tar.gz/source/encoder/search.h -> x265_2.4.tar.gz/source/encoder/search.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/encoder/sei.cpp -> x265_2.4.tar.gz/source/encoder/sei.cpp Changed
71
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *
8
@@ -38,24 +38,38 @@
9
  * in bitstream bs */
10
 void SEI::write(Bitstream& bs, const SPS& sps)
11
 {
12
-    BitCounter count;
13
-    m_bitIf = &count;
14
-
15
-    /* virtual writeSEI method, write to bit counter */
16
-    writeSEI(sps);
17
-
18
+    uint32_t type = m_payloadType;
19
     m_bitIf = &bs;
20
-    uint32_t type = payloadType();
21
-    for (; type >= 0xff; type -= 0xff)
22
-        WRITE_CODE(0xff, 8, "payload_type");
23
+    BitCounter count;
24
+    bool hrdTypes = (m_payloadType == ACTIVE_PARAMETER_SETS || m_payloadType == PICTURE_TIMING || m_payloadType == BUFFERING_PERIOD);
25
+    if (hrdTypes)
26
+    {
27
+        m_bitIf = &count;
28
+        /* virtual writeSEI method, write to bit counter to determine size */
29
+        writeSEI(sps);
30
+        m_bitIf = &bs;
31
+        uint32_t payloadType = m_payloadType;
32
+        for (; payloadType >= 0xff; payloadType -= 0xff)
33
+            WRITE_CODE(0xff, 8, "payload_type");
34
+    }
35
     WRITE_CODE(type, 8, "payload_type");
36
+    uint32_t payloadSize;
37
+    if (hrdTypes || m_payloadType == USER_DATA_UNREGISTERED)
38
+    {
39
+        if (hrdTypes)
40
+        {
41
+            X265_CHECK(0 == (count.getNumberOfWrittenBits() & 7), "payload unaligned\n");
42
+            payloadSize = count.getNumberOfWrittenBits() >> 3;
43
+        }
44
+        else
45
+            payloadSize = m_payloadSize + 16;
46
 
47
-    X265_CHECK(0 == (count.getNumberOfWrittenBits() & 7), "payload unaligned\n");
48
-    uint32_t payloadSize = count.getNumberOfWrittenBits() >> 3;
49
-    for (; payloadSize >= 0xff; payloadSize -= 0xff)
50
-        WRITE_CODE(0xff, 8, "payload_size");
51
-    WRITE_CODE(payloadSize, 8, "payload_size");
52
-
53
+        for (; payloadSize >= 0xff; payloadSize -= 0xff)
54
+            WRITE_CODE(0xff, 8, "payload_size");
55
+        WRITE_CODE(payloadSize, 8, "payload_size");
56
+    }
57
+    else if(m_payloadType != USER_DATA_REGISTERED_ITU_T_T35)
58
+        WRITE_CODE(m_payloadSize, 8, "payload_size");
59
     /* virtual writeSEI method, write to bs */
60
     writeSEI(sps);
61
 }
62
@@ -72,3 +86,8 @@
63
         }
64
     }
65
 }
66
+
67
+void SEI::setSize(uint32_t size)
68
+{
69
+    m_payloadSize = size;
70
+}
71
x265_2.3.tar.gz/source/encoder/sei.h -> x265_2.4.tar.gz/source/encoder/sei.h Changed
288
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
-* Copyright (C) 2013 x265 project
4
+* Copyright (C) 2013-2017 MulticoreWare, Inc
5
 *
6
 * Authors: Steve Borho <steve@borho.org>
7
 *
8
@@ -34,53 +34,34 @@
9
 class SEI : public SyntaxElementWriter
10
 {
11
 public:
12
+    /* SEI users call write() to marshal an SEI to a bitstream.
13
+     * The write() method calls writeSEI() which encodes the header */
14
+    void write(Bitstream& bs, const SPS& sps);
15
 
16
-    /* SEI users call write() to marshal an SEI to a bitstream. SEI
17
-     * subclasses may implement write() or accept the default write()
18
-     * method which calls writeSEI() with a bitcounter to determine
19
-     * the size, then it encodes the header and calls writeSEI a
20
-     * second time for the real encode. */
21
-    virtual void write(Bitstream& bs, const SPS& sps);
22
-
23
+    void setSize(uint32_t size);
24
     virtual ~SEI() {}
25
-
26
 protected:
27
-
28
-    virtual SEIPayloadType payloadType() const = 0;
29
-
30
-    virtual void writeSEI(const SPS&) { X265_CHECK(0, "empty writeSEI method called\n");  }
31
-
32
+    SEIPayloadType  m_payloadType;
33
+    uint32_t        m_payloadSize;
34
+    virtual void writeSEI(const SPS&) = 0;
35
     void writeByteAlign();
36
 };
37
 
38
 class SEIuserDataUnregistered : public SEI
39
 {
40
 public:
41
-
42
-    SEIPayloadType payloadType() const { return m_payloadType; }
43
-
44
-    SEIuserDataUnregistered() : m_userData(NULL) {}
45
-
46
+    SEIuserDataUnregistered() : m_userData(NULL)
47
+    {
48
+        m_payloadType = USER_DATA_UNREGISTERED;
49
+        m_payloadSize = 0;
50
+    }
51
     static const uint8_t m_uuid_iso_iec_11578[16];
52
-    SEIPayloadType m_payloadType;
53
-    uint32_t m_userDataLength;
54
     uint8_t *m_userData;
55
-
56
-    void write(Bitstream& bs, const SPS&)
57
+    void writeSEI(const SPS&)
58
     {
59
-        m_bitIf = &bs;
60
-
61
-        WRITE_CODE(m_payloadType, 8, "payload_type");
62
-
63
-        uint32_t payloadSize = 16 + m_userDataLength;
64
-        for (; payloadSize >= 0xff; payloadSize -= 0xff)
65
-            WRITE_CODE(0xff, 8, "payload_size");
66
-        WRITE_CODE(payloadSize, 8, "payload_size");
67
-
68
         for (uint32_t i = 0; i < 16; i++)
69
             WRITE_CODE(m_uuid_iso_iec_11578[i], 8, "sei.uuid_iso_iec_11578[i]");
70
-
71
-        for (uint32_t i = 0; i < m_userDataLength; i++)
72
+        for (uint32_t i = 0; i < m_payloadSize; i++)
73
             WRITE_CODE(m_userData[i], 8, "user_data");
74
     }
75
 };
76
@@ -88,15 +69,16 @@
77
 class SEIMasteringDisplayColorVolume : public SEI
78
 {
79
 public:
80
-
81
+    SEIMasteringDisplayColorVolume()
82
+    {
83
+        m_payloadType = MASTERING_DISPLAY_INFO;
84
+        m_payloadSize = (8 * 2 + 2 * 4);
85
+    }
86
     uint16_t displayPrimaryX[3];
87
     uint16_t displayPrimaryY[3];
88
     uint16_t whitePointX, whitePointY;
89
     uint32_t maxDisplayMasteringLuminance;
90
     uint32_t minDisplayMasteringLuminance;
91
-
92
-    SEIPayloadType payloadType() const { return MASTERING_DISPLAY_INFO; }
93
-
94
     bool parse(const char* value)
95
     {
96
         return sscanf(value, "G(%hu,%hu)B(%hu,%hu)R(%hu,%hu)WP(%hu,%hu)L(%u,%u)",
97
@@ -106,14 +88,8 @@
98
                       &whitePointX, &whitePointY,
99
                       &maxDisplayMasteringLuminance, &minDisplayMasteringLuminance) == 10;
100
     }
101
-
102
-    void write(Bitstream& bs, const SPS&)
103
+    void writeSEI(const SPS&)
104
     {
105
-        m_bitIf = &bs;
106
-
107
-        WRITE_CODE(MASTERING_DISPLAY_INFO, 8, "payload_type");
108
-        WRITE_CODE(8 * 2 + 2 * 4, 8, "payload_size");
109
-
110
         for (uint32_t i = 0; i < 3; i++)
111
         {
112
             WRITE_CODE(displayPrimaryX[i], 16, "display_primaries_x[ c ]");
113
@@ -129,18 +105,15 @@
114
 class SEIContentLightLevel : public SEI
115
 {
116
 public:
117
-
118
+    SEIContentLightLevel()
119
+    {
120
+        m_payloadType = CONTENT_LIGHT_LEVEL_INFO;
121
+        m_payloadSize = 4;
122
+    }
123
     uint16_t max_content_light_level;
124
     uint16_t max_pic_average_light_level;
125
-
126
-    SEIPayloadType payloadType() const { return CONTENT_LIGHT_LEVEL_INFO; }
127
-
128
-    void write(Bitstream& bs, const SPS&)
129
+    void writeSEI(const SPS&)
130
     {
131
-        m_bitIf = &bs;
132
-
133
-        WRITE_CODE(CONTENT_LIGHT_LEVEL_INFO, 8, "payload_type");
134
-        WRITE_CODE(4, 8, "payload_size");
135
         WRITE_CODE(max_content_light_level,     16, "max_content_light_level");
136
         WRITE_CODE(max_pic_average_light_level, 16, "max_pic_average_light_level");
137
     }
138
@@ -149,42 +122,22 @@
139
 class SEIDecodedPictureHash : public SEI
140
 {
141
 public:
142
-
143
-    SEIPayloadType payloadType() const { return DECODED_PICTURE_HASH; }
144
-
145
+    SEIDecodedPictureHash()
146
+    {
147
+        m_payloadType = DECODED_PICTURE_HASH;
148
+        m_payloadSize = 0;
149
+    }
150
     enum Method
151
     {
152
         MD5,
153
         CRC,
154
         CHECKSUM,
155
     } m_method;
156
-
157
     uint8_t m_digest[3][16];
158
-
159
-    void write(Bitstream& bs, const SPS& sps)
160
+    void writeSEI(const SPS& sps)
161
     {
162
-        m_bitIf = &bs;
163
-
164
         int planes = (sps.chromaFormatIdc != X265_CSP_I400) ? 3 : 1;
165
-
166
-        WRITE_CODE(DECODED_PICTURE_HASH, 8, "payload_type");
167
-
168
-        switch (m_method)
169
-        {
170
-        case MD5:
171
-            WRITE_CODE(1 + 16 * planes, 8, "payload_size");
172
-            WRITE_CODE(MD5, 8, "hash_type");
173
-            break;
174
-        case CRC:
175
-            WRITE_CODE(1 + 2 * planes, 8, "payload_size");
176
-            WRITE_CODE(CRC, 8, "hash_type");
177
-            break;
178
-        case CHECKSUM:
179
-            WRITE_CODE(1 + 4 * planes, 8, "payload_size");
180
-            WRITE_CODE(CHECKSUM, 8, "hash_type");
181
-            break;
182
-        }
183
-
184
+        WRITE_CODE(m_method, 8, "hash_type");
185
         for (int yuvIdx = 0; yuvIdx < planes; yuvIdx++)
186
         {
187
             if (m_method == MD5)
188
@@ -209,9 +162,11 @@
189
 class SEIActiveParameterSets : public SEI
190
 {
191
 public:
192
-
193
-    SEIPayloadType payloadType() const { return ACTIVE_PARAMETER_SETS; }
194
-
195
+    SEIActiveParameterSets()
196
+    {
197
+        m_payloadType = ACTIVE_PARAMETER_SETS;
198
+        m_payloadSize = 0;
199
+    }
200
     bool m_selfContainedCvsFlag;
201
     bool m_noParamSetUpdateFlag;
202
 
203
@@ -229,16 +184,14 @@
204
 class SEIBufferingPeriod : public SEI
205
 {
206
 public:
207
-
208
-    SEIPayloadType payloadType() const { return BUFFERING_PERIOD; }
209
-
210
     SEIBufferingPeriod()
211
         : m_cpbDelayOffset(0)
212
         , m_dpbDelayOffset(0)
213
         , m_auCpbRemovalDelayDelta(1)
214
     {
215
+        m_payloadType = BUFFERING_PERIOD;
216
+        m_payloadSize = 0;
217
     }
218
-
219
     bool     m_cpbDelayOffset;
220
     bool     m_dpbDelayOffset;
221
     uint32_t m_initialCpbRemovalDelay;
222
@@ -263,9 +216,11 @@
223
 class SEIPictureTiming : public SEI
224
 {
225
 public:
226
-
227
-    SEIPayloadType payloadType() const { return PICTURE_TIMING; }
228
-
229
+    SEIPictureTiming()
230
+    {
231
+        m_payloadType = PICTURE_TIMING;
232
+        m_payloadSize = 0;
233
+    }
234
     uint32_t  m_picStruct;
235
     uint32_t  m_sourceScanType;
236
     bool      m_duplicateFlag;
237
@@ -298,9 +253,6 @@
238
 class SEIRecoveryPoint : public SEI
239
 {
240
 public:
241
-
242
-    SEIPayloadType payloadType() const { return RECOVERY_POINT; }
243
-
244
     int  m_recoveryPocCnt;
245
     bool m_exactMatchingFlag;
246
     bool m_brokenLinkFlag;
247
@@ -313,6 +265,39 @@
248
         writeByteAlign();
249
     }
250
 };
251
-}
252
 
253
+//seongnam.oh@samsung.com :: for the Creative Intent Meta Data Encoding
254
+class SEICreativeIntentMeta : public SEI
255
+{
256
+public:
257
+    SEICreativeIntentMeta()
258
+    {
259
+        m_payloadType = USER_DATA_REGISTERED_ITU_T_T35;
260
+        m_payloadSize = 0;
261
+    }
262
+
263
+    uint8_t *cim;
264
+
265
+    // daniel.vt@samsung.com :: for the Creative Intent Meta Data Encoding ( seongnam.oh@samsung.com )
266
+    void writeSEI(const SPS&)
267
+    {
268
+        if (!cim)
269
+            return;
270
+
271
+        int i = 0;
272
+        int payloadSize = m_payloadSize;
273
+        while (cim[i] == 0xFF)
274
+        {
275
+            i++;
276
+            payloadSize += cim[i];
277
+            WRITE_CODE(0xFF, 8, "payload_size");
278
+        }
279
+        WRITE_CODE(payloadSize, 8, "payload_size");
280
+        i++;
281
+        payloadSize += i;
282
+        for (; i < payloadSize; ++i)
283
+            WRITE_CODE(cim[i], 8, "creative_intent_metadata");
284
+    }
285
+};
286
+}
287
 #endif // ifndef X265_SEI_H
288
x265_2.3.tar.gz/source/encoder/slicetype.cpp -> x265_2.4.tar.gz/source/encoder/slicetype.cpp Changed
61
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Gopu Govindaswamy <gopu@multicorewareinc.com>
7
  *          Steve Borho <steve@borho.org>
8
@@ -105,6 +105,21 @@
9
     x265_emms();
10
     return var;
11
 }
12
+/* Find the sum of pixels of each block for luma plane */
13
+uint32_t LookaheadTLD::lumaSumCu(Frame* curFrame, uint32_t blockX, uint32_t blockY, uint32_t qgSize)
14
+{
15
+    intptr_t stride = curFrame->m_fencPic->m_stride;
16
+    intptr_t blockOffsetLuma = blockX + (blockY * stride);
17
+    uint64_t sum_ssd;
18
+
19
+    if (qgSize == 8)
20
+        sum_ssd = primitives.cu[BLOCK_8x8].var(curFrame->m_fencPic->m_picOrg[0] + blockOffsetLuma, stride);
21
+    else
22
+        sum_ssd = primitives.cu[BLOCK_16x16].var(curFrame->m_fencPic->m_picOrg[0] + blockOffsetLuma, stride);
23
+
24
+    x265_emms();
25
+    return (uint32_t)sum_ssd;
26
+}
27
 
28
 void LookaheadTLD::calcAdaptiveQuantFrame(Frame *curFrame, x265_param* param)
29
 {
30
@@ -227,6 +242,30 @@
31
                     uint32_t energy = acEnergyCu(curFrame, blockX, blockY, param->internalCsp,param->rc.qgSize);
32
                     qp_adj = strength * (X265_LOG2(X265_MAX(energy, 1)) - (modeOneConst + 2 * (X265_DEPTH - 8)));
33
                 }
34
+
35
+                if (param->bHDROpt)
36
+                {
37
+                    uint32_t sum = lumaSumCu(curFrame, blockX, blockY, param->rc.qgSize);
38
+                    uint32_t lumaAvg = sum / (loopIncr * loopIncr);
39
+                    if (lumaAvg < 301)
40
+                        qp_adj += 3;
41
+                    else if (lumaAvg >= 301 && lumaAvg < 367)
42
+                        qp_adj += 2;
43
+                    else if (lumaAvg >= 367 && lumaAvg < 434)
44
+                        qp_adj += 1;
45
+                    else if (lumaAvg >= 501 && lumaAvg < 567)
46
+                        qp_adj -= 1;
47
+                    else if (lumaAvg >= 567 && lumaAvg < 634)
48
+                        qp_adj -= 2;
49
+                    else if (lumaAvg >= 634 && lumaAvg < 701)
50
+                        qp_adj -= 3;
51
+                    else if (lumaAvg >= 701 && lumaAvg < 767)
52
+                        qp_adj -= 4;
53
+                    else if (lumaAvg >= 767 && lumaAvg < 834)
54
+                        qp_adj -= 5;
55
+                    else if (lumaAvg >= 834)
56
+                        qp_adj -= 6;
57
+                }
58
                 if (quantOffsets != NULL)
59
                     qp_adj += quantOffsets[blockXY];
60
                 curFrame->m_lowres.qpAqOffset[blockXY] = qp_adj;
61
x265_2.3.tar.gz/source/encoder/slicetype.h -> x265_2.4.tar.gz/source/encoder/slicetype.h Changed
16
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -91,6 +91,7 @@
9
 protected:
10
 
11
     uint32_t acEnergyCu(Frame* curFrame, uint32_t blockX, uint32_t blockY, int csp, uint32_t qgSize);
12
+    uint32_t lumaSumCu(Frame* curFrame, uint32_t blockX, uint32_t blockY, uint32_t qgSize);
13
     uint32_t weightCostLuma(Lowres& fenc, Lowres& ref, WeightParam& wp);
14
     bool     allocWeightedRef(Lowres& fenc);
15
 };
16
x265_2.3.tar.gz/source/encoder/weightPrediction.cpp -> x265_2.4.tar.gz/source/encoder/weightPrediction.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Author: Shazeb Nawaz Khan <shazeb@multicorewareinc.com>
7
  *         Steve Borho <steve@borho.org>
8
x265_2.3.tar.gz/source/input/input.cpp -> x265_2.4.tar.gz/source/input/input.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/input/input.h -> x265_2.4.tar.gz/source/input/input.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/input/y4m.cpp -> x265_2.4.tar.gz/source/input/y4m.cpp Changed
24
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
@@ -141,7 +141,14 @@
9
     if (info.skipFrames)
10
     {
11
 #if X86_64
12
-        ifs->seekg((uint64_t)estFrameSize * info.skipFrames, ios::cur);
13
+        if (ifs != &cin)
14
+            ifs->seekg((uint64_t)estFrameSize * info.skipFrames, ios::cur);
15
+        else
16
+            for (int i = 0; i < info.skipFrames; i++)
17
+            {
18
+                ifs->read(buf[0], estFrameSize - framesize);
19
+                ifs->read(buf[0], framesize);
20
+            }
21
 #else
22
         for (int i = 0; i < info.skipFrames; i++)
23
             ifs->ignore(estFrameSize);
24
x265_2.3.tar.gz/source/input/y4m.h -> x265_2.4.tar.gz/source/input/y4m.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/input/yuv.cpp -> x265_2.4.tar.gz/source/input/yuv.cpp Changed
21
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
@@ -131,7 +131,11 @@
9
     if (info.skipFrames)
10
     {
11
 #if X86_64
12
-        ifs->seekg((uint64_t)framesize * info.skipFrames, ios::cur);
13
+        if (ifs != &cin)
14
+            ifs->seekg((uint64_t)framesize * info.skipFrames, ios::cur);
15
+        else
16
+            for (int i = 0; i < info.skipFrames; i++)
17
+                ifs->read(buf[0], framesize);
18
 #else
19
         for (int i = 0; i < info.skipFrames; i++)
20
             ifs->ignore(framesize);
21
x265_2.3.tar.gz/source/input/yuv.h -> x265_2.4.tar.gz/source/input/yuv.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/output/output.cpp -> x265_2.4.tar.gz/source/output/output.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013-2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Xinyue Lu <i@7086.in>
8
x265_2.3.tar.gz/source/output/output.h -> x265_2.4.tar.gz/source/output/output.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013-2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Xinyue Lu <i@7086.in>
8
x265_2.3.tar.gz/source/output/raw.cpp -> x265_2.4.tar.gz/source/output/raw.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013-2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Xinyue Lu <i@7086.in>
8
x265_2.3.tar.gz/source/output/raw.h -> x265_2.4.tar.gz/source/output/raw.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013-2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Xinyue Lu <i@7086.in>
8
x265_2.3.tar.gz/source/output/reconplay.cpp -> x265_2.4.tar.gz/source/output/reconplay.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Peixuan Zhang <zhangpeixuancn@gmail.com>
7
  *          Chunli Zhang <chunli@multicorewareinc.com>
8
x265_2.3.tar.gz/source/output/reconplay.h -> x265_2.4.tar.gz/source/output/reconplay.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Peixuan Zhang <zhangpeixuancn@gmail.com>
7
  *          Chunli Zhang <chunli@multicorewareinc.com>
8
x265_2.3.tar.gz/source/output/y4m.cpp -> x265_2.4.tar.gz/source/output/y4m.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/output/y4m.h -> x265_2.4.tar.gz/source/output/y4m.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/output/yuv.cpp -> x265_2.4.tar.gz/source/output/yuv.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/output/yuv.h -> x265_2.4.tar.gz/source/output/yuv.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/profile/PPA/ppa.cpp -> x265_2.4.tar.gz/source/profile/PPA/ppa.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/profile/PPA/ppa.h -> x265_2.4.tar.gz/source/profile/PPA/ppa.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/profile/PPA/ppaApi.h -> x265_2.4.tar.gz/source/profile/PPA/ppaApi.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/profile/vtune/vtune.cpp -> x265_2.4.tar.gz/source/profile/vtune/vtune.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/profile/vtune/vtune.h -> x265_2.4.tar.gz/source/profile/vtune/vtune.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/test/checkasm-a.asm -> x265_2.4.tar.gz/source/test/checkasm-a.asm Changed
12
 
1
@@ -1,8 +1,8 @@
2
 ;*****************************************************************************
3
 ;* checkasm-a.asm: assembly check tool
4
 ;*****************************************************************************
5
-;* Copyright (C) 2008-2014 x264 project
6
-;* Copyright (C) 2013-2015 x265 project
7
+;* Copyright (C) 2003-2013 x264 project
8
+;* Copyright (C) 2013-2017 MulticoreWare, Inc
9
 ;*
10
 ;* Authors: Loren Merritt <lorenm@u.washington.edu>
11
 ;*          Henrik Gramner <henrik@gramner.com>
12
x265_2.3.tar.gz/source/test/checkasm-arm.S -> x265_2.4.tar.gz/source/test/checkasm-arm.S Changed
10
 
1
@@ -1,7 +1,7 @@
2
 /****************************************************************************
3
  * checkasm-arm.S: assembly check tool
4
  *****************************************************************************
5
- * Copyright (C) 2016 x265 project
6
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
7
  *
8
  * Authors: Martin Storsjo <martin@martin.st>
9
  *          Dnyaneshwar Gorade <dnyaneshwar@multicorewareinc.com>
10
x265_2.3.tar.gz/source/test/intrapredharness.cpp -> x265_2.4.tar.gz/source/test/intrapredharness.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Min Chen <chenm003@163.com>
7
  *
8
x265_2.3.tar.gz/source/test/intrapredharness.h -> x265_2.4.tar.gz/source/test/intrapredharness.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Min Chen <chenm003@163.com>
7
  *
8
x265_2.3.tar.gz/source/test/ipfilterharness.cpp -> x265_2.4.tar.gz/source/test/ipfilterharness.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Devaki <deepthidevaki@multicorewareinc.com>,
7
  *          Rajesh Paulraj <rajesh@multicorewareinc.com>
8
x265_2.3.tar.gz/source/test/ipfilterharness.h -> x265_2.4.tar.gz/source/test/ipfilterharness.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Deepthi Devaki <deepthidevaki@multicorewareinc.com>,
7
  *          Rajesh Paulraj <rajesh@multicorewareinc.com>
8
x265_2.3.tar.gz/source/test/mbdstharness.cpp -> x265_2.4.tar.gz/source/test/mbdstharness.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <min.chen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/test/mbdstharness.h -> x265_2.4.tar.gz/source/test/mbdstharness.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <min.chen@multicorewareinc.com>
8
x265_2.3.tar.gz/source/test/pixelharness.cpp -> x265_2.4.tar.gz/source/test/pixelharness.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/test/pixelharness.h -> x265_2.4.tar.gz/source/test/pixelharness.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/test/regression-tests.txt -> x265_2.4.tar.gz/source/test/regression-tests.txt Changed
42
 
1
@@ -17,17 +17,17 @@
2
 BasketballDrive_1920x1080_50.y4m,--preset faster --aq-strength 2 --merange 190 --slices 3
3
 BasketballDrive_1920x1080_50.y4m,--preset medium --ctu 16 --max-tu-size 8 --subme 7 --qg-size 16 --cu-lossless --tu-inter-depth 3 --limit-tu 1
4
 BasketballDrive_1920x1080_50.y4m,--preset medium --keyint -1 --nr-inter 100 -F4 --no-sao
5
-BasketballDrive_1920x1080_50.y4m,--preset medium --no-cutree --analysis-mode=save --bitrate 7000 --limit-modes,--preset medium --no-cutree --analysis-mode=load --bitrate 7000 --limit-modes
6
+BasketballDrive_1920x1080_50.y4m,--preset medium --no-cutree --analysis-mode=save --refine-level 2 --bitrate 7000 --limit-modes,--preset medium --no-cutree --analysis-mode=load --refine-level 2 --bitrate 7000 --limit-modes
7
 BasketballDrive_1920x1080_50.y4m,--preset slow --nr-intra 100 -F4 --aq-strength 3 --qg-size 16 --limit-refs 1
8
 BasketballDrive_1920x1080_50.y4m,--preset slower --lossless --chromaloc 3 --subme 0 --limit-tu 4
9
-BasketballDrive_1920x1080_50.y4m,--preset slower --no-cutree --analysis-mode=save --bitrate 7000,--preset slower --no-cutree --analysis-mode=load --bitrate 7000
10
+BasketballDrive_1920x1080_50.y4m,--preset slower --no-cutree --analysis-mode=save --refine-level 10 --bitrate 7000 --limit-tu 0,--preset slower --no-cutree --analysis-mode=load --refine-level 10 --bitrate 7000 --limit-tu 0
11
 BasketballDrive_1920x1080_50.y4m,--preset veryslow --crf 4 --cu-lossless --pmode --limit-refs 1 --aq-mode 3 --limit-tu 3
12
 BasketballDrive_1920x1080_50.y4m,--preset veryslow --no-cutree --analysis-mode=save --bitrate 7000 --tskip-fast --limit-tu 4,--preset veryslow --no-cutree --analysis-mode=load --bitrate 7000  --tskip-fast --limit-tu 4
13
 BasketballDrive_1920x1080_50.y4m,--preset veryslow --recon-y4m-exec "ffplay -i pipe:0 -autoexit"
14
 Coastguard-4k.y4m,--preset ultrafast --recon-y4m-exec "ffplay -i pipe:0 -autoexit"
15
 Coastguard-4k.y4m,--preset superfast --tune grain --overscan=crop
16
 Coastguard-4k.y4m,--preset superfast --tune grain --pme --aq-strength 2 --merange 190
17
-Coastguard-4k.y4m,--preset veryfast --no-cutree --analysis-mode=save --bitrate 15000,--preset veryfast --no-cutree --analysis-mode=load --bitrate 15000
18
+Coastguard-4k.y4m,--preset veryfast --no-cutree --analysis-mode=save --refine-level 1 --bitrate 15000,--preset veryfast --no-cutree --analysis-mode=load --refine-level 1 --bitrate 15000
19
 Coastguard-4k.y4m,--preset medium --rdoq-level 1 --tune ssim --no-signhide --me umh --slices 2
20
 Coastguard-4k.y4m,--preset slow --tune psnr --cbqpoffs -1 --crqpoffs 1 --limit-refs 1
21
 CrowdRun_1920x1080_50_10bit_422.yuv,--preset ultrafast --weightp --tune zerolatency --qg-size 16
22
@@ -68,8 +68,8 @@
23
 KristenAndSara_1280x720_60.y4m,--preset slower --pmode --max-tu-size 8 --limit-refs 0 --limit-modes --limit-tu 1
24
 NebutaFestival_2560x1600_60_10bit_crop.yuv,--preset superfast --tune psnr
25
 NebutaFestival_2560x1600_60_10bit_crop.yuv,--preset medium --tune grain --limit-refs 2
26
-NebutaFestival_2560x1600_60_10bit_crop.yuv,--preset slow --no-cutree --analysis-mode=save --bitrate 9000,--preset slow --no-cutree --analysis-mode=load --bitrate 9000
27
-News-4k.y4m,--preset ultrafast --no-cutree --analysis-mode=save --bitrate 15000,--preset ultrafast --no-cutree --analysis-mode=load --bitrate 15000
28
+NebutaFestival_2560x1600_60_10bit_crop.yuv,--preset slow --no-cutree --analysis-mode=save --rd 5 --refine-level 10 --bitrate 9000,--preset slow --no-cutree --analysis-mode=load --rd 5 --refine-level 10 --bitrate 9000
29
+News-4k.y4m,--preset ultrafast --no-cutree --analysis-mode=save --refine-level 2 --bitrate 15000,--preset ultrafast --no-cutree --analysis-mode=load --refine-level 2 --bitrate 15000
30
 News-4k.y4m,--preset superfast --lookahead-slices 6 --aq-mode 0
31
 News-4k.y4m,--preset superfast --slices 4 --aq-mode 0 
32
 News-4k.y4m,--preset medium --tune ssim --no-sao --qg-size 16
33
@@ -123,7 +123,7 @@
34
 old_town_cross_444_720p50.y4m,--preset superfast --weightp --min-cu 16 --limit-modes
35
 old_town_cross_444_720p50.y4m,--preset veryfast --qp 1 --tune ssim
36
 old_town_cross_444_720p50.y4m,--preset faster --rd 1 --tune zero-latency
37
-old_town_cross_444_720p50.y4m,--preset fast --no-cutree --analysis-mode=save --bitrate 3000 --early-skip,--preset fast --no-cutree --analysis-mode=load --bitrate 3000 --early-skip
38
+old_town_cross_444_720p50.y4m,--preset fast --no-cutree --analysis-mode=save --refine-level 1 --bitrate 3000 --early-skip,--preset fast --no-cutree --analysis-mode=load --refine-level 1 --bitrate 3000 --early-skip
39
 old_town_cross_444_720p50.y4m,--preset medium --keyint -1 --no-weightp --ref 6
40
 old_town_cross_444_720p50.y4m,--preset slow --rdoq-level 1 --early-skip --ref 7 --no-b-pyramid
41
 old_town_cross_444_720p50.y4m,--preset slower --crf 4 --cu-lossless
42
x265_2.3.tar.gz/source/test/smoke-tests.txt -> x265_2.4.tar.gz/source/test/smoke-tests.txt Changed
9
 
1
@@ -19,6 +19,6 @@
2
 DucksAndLegs_1920x1080_60_10bit_422.yuv,--preset=veryfast --min-cu 16
3
 DucksAndLegs_1920x1080_60_10bit_422.yuv,--preset=fast --weightb --interlace bff
4
 DucksAndLegs_1920x1080_60_10bit_422.yuv,--preset=veryslow --limit-ref 1 --limit-mode --tskip --limit-tu 1
5
-
6
+CrowdRun_1920x1080_50_10bit_444.yuv,--preset=superfast --bitrate 7000 --sao --limit-sao
7
 # Main12 intraCost overflow bug test
8
 720p50_parkrun_ter.y4m,--preset medium
9
x265_2.3.tar.gz/source/test/testbench.cpp -> x265_2.4.tar.gz/source/test/testbench.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Gopu Govindaswamy <gopu@govindaswamy.org>
7
  *          Mandar Gurav <mandar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/test/testharness.h -> x265_2.4.tar.gz/source/test/testharness.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
x265_2.3.tar.gz/source/x265-extras.cpp -> x265_2.4.tar.gz/source/x265-extras.cpp Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Selvakumar Nithiyaruban <selvakumar@multicorewareinc.com>
8
x265_2.3.tar.gz/source/x265-extras.h -> x265_2.4.tar.gz/source/x265-extras.h Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2015 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/x265.cpp -> x265_2.4.tar.gz/source/x265.cpp Changed
16
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
@@ -50,6 +50,7 @@
9
 #define CONSOLE_TITLE_SIZE 200
10
 #ifdef _WIN32
11
 #include <windows.h>
12
+#define SetThreadExecutionState(es)
13
 static char orgConsoleTitle[CONSOLE_TITLE_SIZE] = "";
14
 #else
15
 #define GetConsoleTitle(t, n)
16
x265_2.3.tar.gz/source/x265.h -> x265_2.4.tar.gz/source/x265.h Changed
96
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -99,6 +99,7 @@
9
     uint32_t         numCUsInFrame;
10
     uint32_t         numPartitions;
11
     int              bScenecut;
12
+    void*            wt;
13
     void*            interData;
14
     void*            intraData;
15
 } x265_analysis_data;
16
@@ -960,12 +961,9 @@
17
 
18
     /* Enable weighted prediction in B slices. Default is disabled */
19
     int       bEnableWeightedBiPred;
20
-
21
     /* Enable source pixels in motion estimation. Default is disabled */
22
-    int      bSourceReferenceEstimation;
23
-
24
+    int       bSourceReferenceEstimation;
25
     /*== Loop Filters ==*/
26
-
27
     /* Enable the deblocking loop filter, which improves visual quality by
28
      * reducing blocking effects at block edges, particularly at lower bitrates
29
      * or higher QP. When enabled it adds another CU row of reference lag,
30
@@ -1343,30 +1341,23 @@
31
 
32
     /* Enable storing commonly RPS in SPS in multi pass mode */
33
     int       bMultiPassOptRPS;
34
-
35
     /* This value represents the percentage difference between the inter cost and
36
     * intra cost of a frame used in scenecut detection. Default 5. */
37
-    double     scenecutBias;
38
-
39
+    double    scenecutBias;
40
     /* Use multiple worker threads dedicated to doing only lookahead instead of sharing
41
     * the worker threads with Frame Encoders. A dedicated lookahead threadpool is created with the
42
     * specified number of worker threads. This can range from 0 upto half the
43
     * hardware threads available for encoding. Using too many threads for lookahead can starve
44
     * resources for frame Encoder and can harm performance. Default is 0 - disabled. */
45
     int       lookaheadThreads;
46
-
47
     /* Optimize CU level QPs to signal consistent deltaQPs in frame for rd level > 4 */
48
-    int        bOptCUDeltaQP;
49
-
50
+    int       bOptCUDeltaQP;
51
     /* Refine analysis in multipass ratecontrol based on analysis information stored */
52
-    int         analysisMultiPassRefine;
53
-
54
+    int       analysisMultiPassRefine;
55
     /* Refine analysis in multipass ratecontrol based on distortion data stored */
56
-    int         analysisMultiPassDistortion;
57
-
58
+    int       analysisMultiPassDistortion;
59
     /* Adaptive Quantization based on relative motion */
60
-    int        bAQMotion;
61
-
62
+    int       bAQMotion;
63
     /* SSIM based RDO, based on residual divisive normalization scheme. Used for mode
64
     * selection during analysis of CTUs, can achieve significant gain in terms of 
65
     * objective quality metrics SSIM and PSNR */
66
@@ -1379,8 +1370,28 @@
67
      * Auto-enabled when max-cll, max-fall, or mastering display info is specified.
68
      * Default is disabled */
69
     int       bEmitHDRSEI;
70
-} x265_param;
71
 
72
+    /* Enable luma and chroma offsets for HDR/WCG content.
73
+     * Default is disabled */
74
+    int       bHDROpt;
75
+
76
+    /* A value between 1 and 10 (both inclusive) determines the level of
77
+    * information stored/reused in save/load analysis-mode. Higher the refine
78
+    * level higher the informtion stored/reused. Default is 5 */
79
+    int       analysisRefineLevel;
80
+
81
+     /* Limit Sample Adaptive Offset filter computation by early terminating SAO
82
+     * process based on inter prediction mode, CTU spatial-domain correlations,
83
+     * and relations between luma and chroma */
84
+    int       bLimitSAO;
85
+
86
+    /* File containing the tone mapping information */
87
+    const char*     toneMapFile;
88
+
89
+    /* Insert tone mapping information only for IDR frames and when the 
90
+     * tone mapping information changes. */
91
+    int       bDhdr10opt;
92
+} x265_param;
93
 /* x265_param_alloc:
94
  *  Allocates an x265_param instance. The returned param structure is not
95
  *  special in any way, but using this method together with x265_param_free()
96
x265_2.3.tar.gz/source/x265_config.h.in -> x265_2.4.tar.gz/source/x265_config.h.in Changed
8
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *
8
x265_2.3.tar.gz/source/x265cli.h -> x265_2.4.tar.gz/source/x265cli.h Changed
65
 
1
@@ -1,5 +1,5 @@
2
 /*****************************************************************************
3
- * Copyright (C) 2013 x265 project
4
+ * Copyright (C) 2013-2017 MulticoreWare, Inc
5
  *
6
  * Authors: Steve Borho <steve@borho.org>
7
  *          Min Chen <chenm003@163.com>
8
@@ -249,6 +249,7 @@
9
     { "no-multi-pass-opt-rps", no_argument, NULL, 0 },
10
     { "analysis-mode",  required_argument, NULL, 0 },
11
     { "analysis-file",  required_argument, NULL, 0 },
12
+    { "refine-level",   required_argument, NULL, 0 },
13
     { "strict-cbr",           no_argument, NULL, 0 },
14
     { "temporal-layers",      no_argument, NULL, 0 },
15
     { "no-temporal-layers",   no_argument, NULL, 0 },
16
@@ -263,6 +264,13 @@
17
     { "no-ssim-rd",           no_argument, NULL, 0 },
18
     { "hdr",                  no_argument, NULL, 0 },
19
     { "no-hdr",               no_argument, NULL, 0 },
20
+    { "hdr-opt",              no_argument, NULL, 0 },
21
+    { "no-hdr-opt",           no_argument, NULL, 0 },
22
+    { "limit-sao",            no_argument, NULL, 0 },
23
+    { "no-limit-sao",         no_argument, NULL, 0 },
24
+    { "dhdr10-info",    required_argument, NULL, 0 },
25
+    { "dhdr10-opt",           no_argument, NULL, 0},
26
+    { "no-dhdr10-opt",        no_argument, NULL, 0},
27
     { 0, 0, 0, 0 },
28
     { 0, 0, 0, 0 },
29
     { 0, 0, 0, 0 },
30
@@ -308,6 +316,10 @@
31
     H1("                                 1 - i420 (4:2:0 default)\n");
32
     H1("                                 2 - i422 (4:2:2)\n");
33
     H1("                                 3 - i444 (4:4:4)\n");
34
+#if ENABLE_DYNAMIC_HDR10
35
+    H0("   --dhdr10-info <filename>      JSON file containing the Creative Intent Metadata to be encoded as Dynamic Tone Mapping \n");
36
+    H0("   --[no-]dhdr10-opt             Insert tone mapping SEI only for IDR frames and when the tone mapping information changes. Default disabled");
37
+#endif
38
     H0("-f/--frames <integer>            Maximum number of frames to encode. Default all\n");
39
     H0("   --seek <integer>              First frame to encode\n");
40
     H1("   --[no-]interlace <bff|tff>    Indicate input pictures are interlace fields in temporal order. Default progressive\n");
41
@@ -421,6 +433,7 @@
42
     H0("   --[no-]strict-cbr             Enable stricter conditions and tolerance for bitrate deviations in CBR mode. Default %s\n", OPT(param->rc.bStrictCbr));
43
     H0("   --analysis-mode <string|int>  save - Dump analysis info into file, load - Load analysis buffers from the file. Default %d\n", param->analysisMode);
44
     H0("   --analysis-file <filename>    Specify file name used for either dumping or reading analysis data.\n");
45
+    H0("   --refine-level <1..10>        Level of analysis refinement indicates amount of info stored/reused in save/load mode, 1:least....10:most. Default %d\n", param->analysisRefineLevel);
46
     H0("   --aq-mode <integer>           Mode for Adaptive Quantization - 0:none 1:uniform AQ 2:auto variance 3:auto variance with bias to dark scenes. Default %d\n", param->rc.aqMode);
47
     H0("   --aq-strength <float>         Reduces blocking and blurring in flat and textured areas (0 to 3.0). Default %.2f\n", param->rc.aqStrength);
48
     H0("   --[no-]aq-motion              Adaptive Quantization based on the relative motion of each CU w.r.t., frame. Default %s\n", OPT(param->bOptCUDeltaQP));
49
@@ -450,6 +463,7 @@
50
     H0("   --[no-]deblock                Enable Deblocking Loop Filter, optionally specify tC:Beta offsets Default %s\n", OPT(param->bEnableLoopFilter));
51
     H0("   --[no-]sao                    Enable Sample Adaptive Offset. Default %s\n", OPT(param->bEnableSAO));
52
     H1("   --[no-]sao-non-deblock        Use non-deblocked pixels, else right/bottom boundary areas skipped. Default %s\n", OPT(param->bSaoNonDeblocked));
53
+    H0("   --[no-]limit-sao              Limit Sample Adaptive Offset types. Default %s\n", OPT(param->bLimitSAO));
54
     H0("\nVUI options:\n");
55
     H0("   --sar <width:height|int>      Sample Aspect Ratio, the ratio of width to height of an individual pixel.\n");
56
     H0("                                 Choose from 0=undef, 1=1:1(\"square\"), 2=12:11, 3=10:11, 4=16:11,\n");
57
@@ -471,6 +485,7 @@
58
     H0("                                    format: G(x,y)B(x,y)R(x,y)WP(x,y)L(max,min)\n");
59
     H0("   --max-cll <string>            Emit content light level info SEI as \"cll,fall\" (HDR)\n");
60
     H0("   --[no-]hdr                    Control dumping of HDR SEI packet. If max-cll or master-display has non-zero values, this is enabled. Default %s\n", OPT(param->bEmitHDRSEI));
61
+    H0("   --[no-]hdr-opt                Add luma and chroma offsets for HDR/WCG content. Default %s\n", OPT(param->bHDROpt));
62
     H0("   --min-luma <integer>          Minimum luma plane value of input source picture\n");
63
     H0("   --max-luma <integer>          Maximum luma plane value of input source picture\n");
64
     H0("\nBitstream options:\n");
65
Refresh

No build results available

Refresh

No rpmlint results available

Request History
enzokiel's avatar

enzokiel created request almost 8 years ago

Update to version 2.4


enzokiel's avatar

enzokiel accepted request almost 8 years ago