doc:appunti:hardware:sjcam-8pro-ambarella-firmware-modding
                Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| doc:appunti:hardware:sjcam-8pro-ambarella-firmware-modding [2022/05/03 21:29] – [Chroma] niccolo | doc:appunti:hardware:sjcam-8pro-ambarella-firmware-modding [2022/06/15 16:47] (current) – [White balance presets] niccolo | ||
|---|---|---|---|
| Line 68: | Line 68: | ||
| ^ U         | 0 ÷ 2048    | Multiplier for the **blue projection** (blue - luma). | ^ U         | 0 ÷ 2048    | Multiplier for the **blue projection** (blue - luma). | ||
| ^ V         | 0 ÷ 2048    | Multiplier for the **red projection** (red - luma). | ^ V         | 0 ÷ 2048    | Multiplier for the **red projection** (red - luma). | ||
| - | ^ Y-offset | + | ^ Y-offset | 
| - | ^ U-offset | + | ^ U-offset | 
| - | ^ V-offset | + | ^ V-offset | 
| + | For the **multiplier**: | ||
| + | |||
| + | For the **offset shift**: a value of **-128** means **-50%** of the full range, a value of **+127** means **+50%** of the full range. | ||
| Values for **Y**, **U** and **V** are unsigned integers in the range **0 ÷ 2048**, values for **Y-offset**, | Values for **Y**, **U** and **V** are unsigned integers in the range **0 ÷ 2048**, values for **Y-offset**, | ||
| Line 166: | Line 169: | ||
| The tables are contained into the **aaa_default_00_Imx377** file (inside the ROMFS section #3), at offsets **0x285**, **0x2E5** and **0x345** respectively. Each exposition table is a matrix of 12x8 bytes; each number represents the exposition weight of a portion of the image, being the image divided in 8 rows and 12 columns. | The tables are contained into the **aaa_default_00_Imx377** file (inside the ROMFS section #3), at offsets **0x285**, **0x2E5** and **0x345** respectively. Each exposition table is a matrix of 12x8 bytes; each number represents the exposition weight of a portion of the image, being the image divided in 8 rows and 12 columns. | ||
| - | ===== Gamma correction | + | ===== Gamma curves | 
| Simply speaking, gamma can make the image **lighter** or **darker** in a **selective** manner, i.e. acting differently on shadows and highlights. By acting differently on the red, green and blue channels, gamma can also do **color balancing**. | Simply speaking, gamma can make the image **lighter** or **darker** in a **selective** manner, i.e. acting differently on shadows and highlights. By acting differently on the red, green and blue channels, gamma can also do **color balancing**. | ||
| Line 172: | Line 175: | ||
| Gamma correction is probably applied in a later stage of the Ambarella video processing pipeline. Gamma is a function that transforms brightness or luminance values, it is usually nonlinear and affects the highlights, midtones, and shadows separately. In our case there are different gamma curves for the three color channles: red, green and blue. Different video formats (4K, 1080, etc) use different gamma correction tables. | Gamma correction is probably applied in a later stage of the Ambarella video processing pipeline. Gamma is a function that transforms brightness or luminance values, it is usually nonlinear and affects the highlights, midtones, and shadows separately. In our case there are different gamma curves for the three color channles: red, green and blue. Different video formats (4K, 1080, etc) use different gamma correction tables. | ||
| - | BitrateEditor exposes and allow the modification of several look-up tables (**LUT**) contained into the files **adj_video_default_0[0-5]_Imx377** and **adj_still_default_0[0-1]_Imx377** (file are contained into firmware section #3). The tables are shown grouped by three, i.e. we work actually on a **3** x **1D-LUT**, one for each color channel: Red, Green and Blue. In the following picture we see the editing of the group called **4K30/ | + | BitrateEditor exposes and allow the modification of several look-up tables (**LUT**) contained into the files **adj_video_default_0[0-5]_Imx377** and **adj_still_default_0[0-1]_Imx377** (file are contained into firmware section #3). The tables are shown grouped by three, i.e. we work actually on a **3** x **1D-LUT**, one for each color channel: Red, Green and Blue. | 
| + | |||
| + | For each color component we have **256 values** arranged for compactness in 16 rows. Each value is likely a **10 bit integer**, BitrateEditor allows you to enter a number ranging from 0 to 1024, but I strictly adivse to remain into the range **%%[0, 1023]%%**. | ||
| + | |||
| + | In the following picture we see the editing of the group called **4K30/ | ||
| {{.: | {{.: | ||
| Line 189: | Line 196: | ||
| ^ Group ^ Contained in file ^ Used for video modes ^ | ^ Group ^ Contained in file ^ Used for video modes ^ | ||
| - | | 4K30/ | + | | 4K30/ | 
| - | | 4K60/ | + | | 4K60/ | 
| - | | FHD60/ | + | | FHD60/ | 
| - | | FHD120/ | + | | FHD120/ | 
| - | | 720@240/ | + | | 720@240/ | 
| + | | 4K30Gyro/ | ||
| | ||| | | ||| | ||
| ^ Group           ^ Contained in file                 ^ Used for photo mode/ | ^ Group           ^ Contained in file                 ^ Used for photo mode/ | ||
| Line 199: | Line 207: | ||
| | Photo-Hi-ISO/ | | Photo-Hi-ISO/ | ||
| - | I have not found any video mode which is affected by tables contained into the file **adj_video_default_05_Imx377**, may be it affects some of the **non active video modes**? | + | It seems rather crazy, but the tables contained into **adj_video_default_05_Imx377** | 
| ==== How gamma curves are mixed together ==== | ==== How gamma curves are mixed together ==== | ||
| Line 424: | Line 433: | ||
| {{.: | {{.: | ||
| + | |||
| + | FIXME: It is not know how this table works. It seems that labels are wrong: **YA_min** and **YB_min** are repeated twice, may be they are **YA_max** and **YB_max**. | ||
| + | |||
| + | White balance is probably applied as a series of linear transformations to the **four raw values** captured by te **[[wp> | ||
| + | |||
| + | ^ Gr | Green on Red | | ||
| + | ^ Gb | Green on Blue | | ||
| + | ^ Ya  | Y channel value of target image? | ||
| + | ^ Yb  | Y channel value of reference image? | ||
| ===== 3D LUT tables ===== | ===== 3D LUT tables ===== | ||
| Line 488: | Line 506: | ||
| * **{{.: | * **{{.: | ||
| * **[[https:// | * **[[https:// | ||
| + | * **[[https:// | ||
doc/appunti/hardware/sjcam-8pro-ambarella-firmware-modding.1651606168.txt.gz · Last modified:  by niccolo
                
                