Skip to content

satgit62/Ultimate-HyperHDR-Ambilight-fine-tuning-experience-for-LG-webOS-with-new-LUT-calibration-

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

88 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Ultimate-HyperHDR-Ambilight-fine-tuning-experience-for-LG-webOS-with-new-LUT-calibration-

This guide here is based on @awawa-dev New LUT Calibration implementations in HyperHDR and @sundermann changes in hyperion-webos fork “nv12” branch.

"ai_calibration" branch was merged into "master" branch and HyperHDR 21.0.0.0beta1 released.

UPDATE from 09.12.2024

According to @awawa-dev, a bug has been discovered in the NV12 backend that affects the SDR LUT (#define LUT_TABLE_FILENAME_SDR "lut_lin_tables.3d"). This is important for all users who use multiple LUTs such as SDR, HDR and DV.

The backend always disables tone mapping when SDR is detected on WebOS. However, tone mapping must always be activated in this case, otherwise it makes no sense to create a separate LUT for SDR. See: awawa-dev/HyperHDR#896 (comment) The automatic activation/deactivation of the HDR Global switch, provided that “HDR to SDR tone mapping” is selected under Network Services, Flatbuffer, only applies when using a single LUT table. With multiple LUTs the tone mapping must always be on. For this reason, I have made the necessary change in the code and recompiled the hyperion-webos backends. If you are using multiple LUT's, please replace the old one with the new hyperion-webos backends.

The implementation and utilization of the NV12 image format in HyperHDR now offers numerous enhancements and the capability to achieve precise color matching even in our exotic LG webOS by utilizing the YUV format in lieu of RGB.

The first step was achieved by @awawa-dev by implementing NV12 in HyperHDR.

Advantages:

The NV12-YUV conversion has been completely moved to HyperHDR, which uses a LUT table for this purpose (no calculations when converting from YUV to RGB). Using the selected LUT, the YUV to RGB conversion and tone mapping can also be performed in one step without loss. This means that we reduce the client load, as not only is the processor load reduced, but no additional resources, e.g., memory, need to be allocated. You also do not need to use external YUV libraries. Reduced load on the connection bandwidth. The NV12 frame is around 50% smaller than the RGB frame. This means that the automatic LUT calibration with YUV coefficient detection can be fully utilized.

Important!

If the NV12 transport mode is used, HyperHDR requires a complete standard LUT table (150 MB). The small flat_lut_lin_tables.3d table used (50 MB) does not contain the necessary YUV conversion tables and only works for RGB tone mapping.

Another problem was the use of a LUT table for different video types. With SDR video material, for example, the colors of the LEDs matched, but with HDR the colors were distorted and very weak with Dolby Vision. Thanks to a new calibration method implemented in HyperHDR, it is now possible to generate LUT tables with different color information depending on the video material being played.

The second step was taken by user @s1mptom, in consultation with @awawa-dev, who himself was not entirely satisfied with the results of the modified backend. He adapted the hyperion-webos backend for the NV12 format and also added the use of multiple LUT tables. This finally makes it possible to use automatically calibrated LUT tables for the three different scenarios such as SDR, HDR+ and Dolby Vision video material in HyperHDR. The NV12 branch has also been implemented by @sundermann.

The following lines of code were added under other changes, by @s1mptom/@sundermann to the definition of the LUT table in the hyperion-webos backend (PicCap).

Source code:

  • #define LUT_TABLE_FILENAME_HDR “lut_lin_tables_hdr.3d”
  • #define LUT_TABLE_FILENAME_DV “lut_lin_tables_dv.3d”
  • #define LUT_TABLE_FILENAME_SDR “lut_lin_tables.3d”

In our case, this means that the new LUTs (lut_lin_tables.3d, lut_lin_tables_dv.3d and lut_lin_tables_hdr.3d) replace the standard LUTs.

For this, @awawa-dev has also added a new LUT calibration option for our WebOS Flatbuffers, which allows us to play different test videos directly on our devices to generate the different LUTs. YUV coefficients are switched during LUT calibration thanks to the native NV12 format. This was not possible for the pure RGB flat buffer stream. Even the first LUT calibration for SDR, using the reference test video for SDR, “test_SDR_yuv420_low_quality”, produced a remarkable color correction.

I have compiled the “hyperhdr-webos-loader” with the following new feature from @awawa-dev and built the installation package based on these changes and the purpose of the calibration:

  • Fix HyperHDR daemon when starting calibration process

  • Fix HyperHDR daemon at screensaver start

The HyperHDR daemon is no longer stopped when the internal screensaver or the custom Aerial Screensaver for webOS is switched on. (Ambilight works)

  • Added support for NV12 image format for flat buffers
  • ai_calibration:
  • Denoising algorithm that significantly improves calibration results with YUV420 format, especially YUV420 LIMITED
  • Added Quarter of frame for NV12 for Flatbuffers Server reduces CPU and memory load
  • Grabber benchmark support for flat buffers
  • Added SDR support for libdile
  • Added support for SDR (BT2020 in SRGB) calibration
  • More precise saving/loading of color images
  • Corrected calibration for 1280×720 recording settings

1.replace backends in hyperion-webos (PicCap):

  • a. Connect to your TV via SSH/Telnet and execute the following command pgrep -fl piccap | while read -r pid _; do kill "$pid"; done to terminate piccap with Hyperion process.
  • b. Download and unzip the hyperion_webos_Release.zip.
  • c. You must then copy all new backend files to /media/developer/apps/usr/palm/services/org.webosbrew.piccap.service/ and replace the old backend files.

Note:

The “hyperion-webos” file may need to be deleted first before it can be replaced. You can use FileZilla or webOS Dev Manager for this purpose. Use the “webOS Dev Manager” only under Connection “Use SSH Server by Homebrew Channel” (Requires Rooted TV) with the username = root, password = alpine and port = 22.

Attention! You should never install the Developer Mode App on a rooted device. This will result in the loss of root.

webOS Dev Manager Connection Mode

webOS Dev Manager Authentication

webOS Dev Manager Files

The easiest way to exchange files is FileZilla.

FileZilla

Attention!

The NV12 must be activated in config.json from /media/developer/apps/usr/palm/services/org.webosbrew.piccap.service/ by inserting the "nv12":true followed by a (,) to the next option and saving it.

If NV12 mode has been successfully activated, this is displayed in the log: [FLATBUFSERVER] (FlatBuffersServer.cpp:338) Received first NV12 frame and instead of “(LutLoader.cpp:x) Index 0 for HDR RGB”, “(LutLoader.cpp:x) Index 1 for HDR YUV” is recognized.

2. HyperHDR installation instructions:

  • a. Start HyperHDR app and stop the services/daemon.
  • b. Start webOS Dev Manager on the PC and uninstall HyperHDR.
  • c. Install HyperHDR version 21.0.0.0alpha0 Build ai_calibration branch from attachment (org.webosbrew.hyperhdr.loader_0.2.0_all.ipk).
  • d. Start HyperHDR app and start the services/daemon.
  • e. Reboot. Make sure that Quick Start+ in the menu of your LG is switched off.
  • f. Use FileZilla or webOS Dev Manager to delete the 50 MB file “flat_lut_lin_tables.3d” from /media/developer/apps/usr/palm/services/org.webosbrew.hyperhdr.loader.service/hyperhdr/.
  • g. Using FileZilla or webOS Dev Manager, also delete the “lut_lin_tables.3d” from /home/root/.hyperhdr/ directory of your TV.
  • h. Download the LUT.zip, unzip it and copy the contents of the LUT folders lut_lin_tables_hdr.3d and lut_lin_tables_dv.3d, to /home/root/.hyperhdr/ using FileZilla or webOS Dev Manager on the TV and copy lut_lin_tables.3d, to /media/developer/apps/usr/palm/services/org.webosbrew.hyperhdr.loader.service/hyperhdr/.
  • i. In HyperHDR under Network Settings, Flatbuffer Server, activate HDR-to-SDR tone mapping in HyperHDR under Network Settings, Flatbuffer Server and, if required, Quarter of Frame for NV12. (Quarter of Frame for NV12 reduces the CPU load when the HyperHDR daemon is active, with relatively little loss of quality)

When switching from an SDR video to an HDR or DV video, the LUT requested by the backend is searched for, loaded into HyperHDR and displayed in the log:

[FLATBUFSERVER] Setting user LUT filename to: 'lut_lin_tables_dv.3d' [FLATBUFSERVER] (LutLoader.cpp:82) LUT file found: /home/root/.hyperhdr/lut_lin_tables_dv.3d

When returning to an SDR video, the SDR LUT (lut_lin_tables.3d) is requested and applied.

Attention!

Since the /home partition is limited in terms of disk space, always make sure that there is enough disk space available for the LUT calibration in /home/root/.hyperhdr/. A full LUT requires approx. 144 MB (150,994,944 bytes) of memory. Otherwise, an invalid LUT with an impermissibly large size will end up there. You can check the size of the partition in Terminal/Putty-SSH with the command df -h. This also determines whether only two or even all three LUTs can operate there.

Alternatively, to avoid the lack of space in /home/root/.hyperhdr/, all three LUT's table can be copied to /media/developer/apps/usr/palm/services/org.webosbrew.hyperhdr.loader.service/hyperhdr/ and symlinks to /home/root/.hyperhdr/ as in the following example:

ln -s /media/developer/apps/usr/palm/services/org.webosbrew.hyperhdr.loader.service/hyperhdr/lut_lin_tables.3d /home/root/.hyperhdr/lut_lin_tables_sdr.3d

ln -s /media/developer/apps/usr/palm/services/org.webosbrew.hyperhdr.loader.service/hyperhdr/lut_lin_tables_hdr.3d /home/root/.hyperhdr/lut_lin_tables_hdr.3d

ln -s /media/developer/apps/usr/palm/services/org.webosbrew.hyperhdr.loader.service/hyperhdr/lut_lin_tables_dv.3d /home/root/.hyperhdr/lut_lin_tables_dv.3d

If you decide to calibrate LUTs yourself, make sure that you set the resolution in PicCap/hyperion-webos to Manuel and set 1280 × 720, save and restart. The new function in HyperHDR “Quarter of frame for NV12” under Network, Flatbuffers server must also be switched off for this process. (otherwise you will get the minimum requirement for calibration of 1280 × 720 in HyperHDR) After a successful calibration process, you can reduce the resolution in PicCap again and reactivate the “Quarter of frame for NV12” in HyperHDR.

Important!

At the end of calibration, the LUT is automatically saved in /home/root/.hyperhdr/ under the name lut_lin_tables.3d. If the calibration was not performed for SDR, the LUT must also be renamed with the correct name lut_lin_tables_hdr.3d or lut_lin_tables_dv.3d and moved to the correct directory.

Note on calibration videos:

SDR refers to content without HDR/HLG or Dolby Vision. For this, you also have to use a calibration video such as test_SDR_yuv420_low_quality or test_SDR_yuv422_low_quality. As YUV422 is not so widespread, I have used test_SDR_yuv420_low_quality.

The same applies to HDR or DV So take the appropriate videos for the desired LUT calibration.

The HDR to SDR tone mapping automatically controls the HDR (Global) switch, under remote control on or off, when SDR or HDR/DV is played. The function should be switched off during calibration. Then you have to switch it on again. Using different players and test files (calibration videos) may slightly affect the calibration result and color reproduction, so it is better to test different combinations if something does not fit.

See also the calibration guide from @awawa-dev: https://github.com/awawa-dev/HyperHDR/wiki/lut-calibration

Source:

Download hyperion-webos: https://github.com/satgit62/hyperion-webos/actions/runs/12232031341/artifacts/2292506957

Download org.webosbrew.hyperhdr.loader_0.2.0_all.ipk: https://github.com/satgit62/hyperhdr-webos-loader/releases/download/latest/org.webosbrew.hyperhdr.loader_0.2.0_all.ipk (HyperHDR 21.0.0.0beta1)

Download three test LUT tables for SDR, HDR+ and DV are available for download at the following link: https://drive.google.com/file/d/1gMcooXS14cIQcl5wXywo37i1imaBJGjW/view?usp=sharing

Download Video calibration test files: https://github.com/awawa-dev/awawa-dev.github.io/tree/master/calibration

https://gist.github.com/Jim-Bar/3cbba684a71d1a9d468a6711a6eddbeb#about-yuv-formats

awawa-dev/HyperHDR#920

awawa-dev/HyperHDR#896

https://github.com/webosbrew/hyperion-webos

https://github.com/satgit62/hyperion-webos/tree/nv12

https://github.com/sundermann/hyperion-webos/tree/nv12

https://github.com/s1mptom/hyperion-webos/tree/main

https://github.com/webosbrew/dev-manager-desktop

https://filezilla-project.org/download.php?type=client

HyperHDR version:

About HyperHDR

LUT_calibration:

LUT_calibration

LUT_calibration:

LUT_calibration1

NV12 Mode Log:

NV12 Mode Log

Quarter of frame for NV12:

Quarter of frame for NV12

Testdateien_calibration

Testdateien_calibration

Video benchmark:

Video benchmark

NV12 coefficients: See https://gist.github.com/Jim-Bar/3cbba684a71d1a9d468a6711a6eddbeb#about-yuv-formats

NV12 coefficients

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

Packages

No packages published