xref: /OK3568_Linux_fs/external/camera_engine_rkaiq/rkaiq/include/iq_parser_v2/sharp_head_v4.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 /*
2  * sharp_head_v1.h
3  *
4  *  Copyright (c) 2021 Rockchip Corporation
5  *
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  *      http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *
18  */
19 
20 #ifndef __CALIBDBV2_SHARPV4_HEADER_H__
21 #define __CALIBDBV2_SHARPV4_HEADER_H__
22 
23 #include "rk_aiq_comm.h"
24 
25 RKAIQ_BEGIN_DECLARE
26 
27 ///////////////////////////sharp//////////////////////////////////////
28 
29 typedef struct CalibDbV2_SharpV4_ISO_Luma_s {
30     // M4_ARRAY_DESC("luma_point", "f32", M4_SIZE(1,8), M4_RANGE(0,1024), "[0, 64, 128, 256, 384, 640, 896, 1024]", M4_DIGIT(1), M4_DYNAMIC(0))
31     float luma_point[8];
32     // M4_ARRAY_DESC("luma_sigma", "f32", M4_SIZE(1,8), M4_RANGE(0,1023), "[8, 10, 10, 12, 14, 12, 12, 10]", M4_DIGIT(1), M4_DYNAMIC(0))
33     float luma_sigma[8];
34     // M4_ARRAY_DESC("hf_clip", "f32", M4_SIZE(1,8), M4_RANGE(0,1023), "[10, 20, 30, 56, 56, 56, 56, 30]", M4_DIGIT(1), M4_DYNAMIC(0))
35     float hf_clip[8];
36     // M4_ARRAY_DESC("local_sharp_strength", "f32", M4_SIZE(1,8), M4_RANGE(0,1023), "[1023, 1023, 1023, 1023, 1023, 1023, 1023, 1023]", M4_DIGIT(1), M4_DYNAMIC(0))
37     float local_sharp_strength[8];
38 } CalibDbV2_SharpV4_ISO_Luma_t;
39 
40 typedef struct CalibDbV2_SharpV4_kernel_s {
41 
42     // M4_ARRAY_DESC("prefilter_coeff", "f32", M4_SIZE(1,3), M4_RANGE(0,1), "[0.2042,0.1238,0.0751]", M4_DIGIT(4), M4_DYNAMIC(0))
43     float prefilter_coeff[3];
44     // M4_ARRAY_DESC("GaussianFilter_coeff", "f32", M4_SIZE(1,6), M4_RANGE(0,1), "[0.2042,0.1238,0.0751]", M4_DIGIT(4), M4_DYNAMIC(0))
45     float GaussianFilter_coeff[6];
46     // M4_ARRAY_DESC("hfBilateralFilter_coeff", "f32", M4_SIZE(1,3), M4_RANGE(0,1), "[0.2042,0.1238,0.0751]", M4_DIGIT(4), M4_DYNAMIC(0))
47     float hfBilateralFilter_coeff[3];
48 } CalibDbV2_SharpV4_kernel_t;
49 
50 typedef struct CalibDbV2_SharpV4_sigma_s {
51 
52     // M4_ARRAY_DESC("prefilter_sigma", "f32", M4_SIZE(1,1), M4_RANGE(0,100), "[1.0]", M4_DIGIT(2), M4_DYNAMIC(0))
53     float prefilter_sigma;
54     // M4_ARRAY_DESC("hfBilateralFilter_sigma", "f32", M4_SIZE(1,1), M4_RANGE(0,100), "[1.0]", M4_DIGIT(2), M4_DYNAMIC(0))
55     float hfBilateralFilter_sigma;
56     // M4_ARRAY_DESC("GaussianFilter_sigma", "f32", M4_SIZE(1,1), M4_RANGE(0,100), "[1.0]", M4_DIGIT(2), M4_DYNAMIC(0))
57     float GaussianFilter_sigma;
58     // M4_ARRAY_DESC("GaussianFilter_radius", "f32", M4_SIZE(1,1), M4_RANGE(1,2), "[2.0]", M4_DIGIT(0), M4_DYNAMIC(0))
59     float GaussianFilter_radius;
60 
61 } CalibDbV2_SharpV4_sigma_t;
62 
63 typedef struct CalibDbV2_SharpV4_Set_ISO_s {
64     // M4_NUMBER_MARK_DESC("iso", "f32", M4_RANGE(50, 204800), "50", M4_DIGIT(1), "index2")
65     float iso;
66 
67     // M4_NUMBER_DESC("pbf_gain", "f32", M4_RANGE(0.0, 2.0), "0.5", M4_DIGIT(2))
68     float pbf_gain;
69     // M4_NUMBER_DESC("pbf_ratio", "f32", M4_RANGE(0.0, 1.0), "0.5", M4_DIGIT(2))
70     float pbf_ratio;
71     // M4_NUMBER_DESC("pbf_add", "f32", M4_RANGE(0.0, 1023.0), "0.0", M4_DIGIT(2))
72     float pbf_add;
73 
74     // M4_NUMBER_DESC("gaus_ratio", "f32", M4_RANGE(0.0, 1.0), "0.0", M4_DIGIT(2))
75     float gaus_ratio;
76 
77     // M4_NUMBER_DESC("sharp_ratio", "f32", M4_RANGE(0.0, 32.0), "0.5", M4_DIGIT(2))
78     float sharp_ratio;
79 
80 
81     // M4_NUMBER_DESC("bf_gain", "f32", M4_RANGE(0.0, 2.0), "0.5", M4_DIGIT(2))
82     float bf_gain;
83     // M4_NUMBER_DESC("bf_ratio", "f32", M4_RANGE(0.0, 1.0), "0.5", M4_DIGIT(2))
84     float bf_ratio;
85     // M4_NUMBER_DESC("bf_add", "f32", M4_RANGE(0.0, 1023.0), "0.0", M4_DIGIT(2))
86     float bf_add;
87 
88     // M4_ARRAY_TABLE_DESC("luma_para", "array_table_ui", "none")
89     CalibDbV2_SharpV4_ISO_Luma_t luma_para;
90 
91     // M4_ARRAY_TABLE_DESC("kernel_para", "array_table_ui", "none")
92     CalibDbV2_SharpV4_kernel_t kernel_para;
93 
94     // M4_ARRAY_TABLE_DESC("kernel_sigma", "array_table_ui", "none")
95     CalibDbV2_SharpV4_sigma_t kernel_sigma;
96 } CalibDbV2_SharpV4_Set_ISO_t;
97 
98 typedef struct CalibDbV2_SharpV4_Set_s {
99     // M4_STRING_MARK_DESC("SNR_Mode", M4_SIZE(1,1), M4_RANGE(0, 64), "LSNR",M4_DYNAMIC(0), "index1")
100     char *SNR_Mode;
101     // M4_STRING_DESC("Sensor_Mode", M4_SIZE(1,1), M4_RANGE(0, 64), "lcg", M4_DYNAMIC(0))
102     char *Sensor_Mode;
103     // M4_STRUCT_LIST_DESC("Tuning_ISO", M4_SIZE_DYNAMIC, "double_index_list")
104     CalibDbV2_SharpV4_Set_ISO_t *Tuning_ISO;
105     int Tuning_ISO_len;
106 } CalibDbV2_SharpV4_Set_t;
107 
108 typedef struct CalibDbV2_SharpV4_Tuning_s {
109     // M4_BOOL_DESC("enable", "1")
110     bool enable;
111 
112     // M4_BOOL_DESC("kernel_sigma_enable", "1")
113     bool kernel_sigma_enable;
114 
115     // M4_STRUCT_LIST_DESC("Setting", M4_SIZE_DYNAMIC, "double_index_list")
116     CalibDbV2_SharpV4_Set_t *Setting;
117     int Setting_len;
118 
119 } CalibDbV2_SharpV4_Tuning_t;
120 
121 typedef struct CalibDbV2_SharpV4_s {
122     // M4_STRING_DESC("Version", M4_SIZE(1,1), M4_RANGE(0, 64), "V3", M4_DYNAMIC(0))
123     char *Version;
124     // M4_STRUCT_DESC("TuningPara", "normal_ui_style")
125     CalibDbV2_SharpV4_Tuning_t TuningPara;
126 } CalibDbV2_SharpV4_t;
127 
128 RKAIQ_END_DECLARE
129 
130 #endif
131 
132