xref: /OK3568_Linux_fs/external/camera_engine_rkaiq/rkaiq/include/iq_parser_v2/sharp_uapi_head_v4.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 /*
2  * sharp_uapi_head_v4.h
3  *
4  *  Copyright (c) 2022 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_UAPI_SHARPV4_HEADER_H__
21 #define __CALIBDBV2_UAPI_SHARPV4_HEADER_H__
22 
23 #include "rk_aiq_comm.h"
24 
25 RKAIQ_BEGIN_DECLARE
26 
27 #define RK_SHARP_V4_LUMA_POINT_NUM             8
28 #define RK_SHARP_V4_PBF_DIAM                    3
29 #define RK_SHARP_V4_RF_DIAM                     5
30 #define RK_SHARP_V4_BF_DIAM                     3
31 
32 
33 typedef struct RK_SHARP_Params_V4_Select_s
34 {
35     // M4_BOOL_DESC("enable", "1")
36     int enable;
37 
38 
39 
40     // M4_ARRAY_DESC("luma_point", "s16", M4_SIZE(1,8), M4_RANGE(0,1024), "[0, 64, 128, 256, 384, 640, 896, 1024]", M4_DIGIT(0), M4_DYNAMIC(0))
41     int16_t luma_point[RK_SHARP_V4_LUMA_POINT_NUM];
42     // M4_ARRAY_DESC("luma_sigma", "s16", M4_SIZE(1,8), M4_RANGE(0,1023), "[8, 10, 10, 12, 14, 12, 12, 10]", M4_DIGIT(0), M4_DYNAMIC(0))
43     int16_t luma_sigma[RK_SHARP_V4_LUMA_POINT_NUM];
44 
45 
46     // M4_NUMBER_DESC("pbf_gain", "f32", M4_RANGE(0.0, 2.0), "0.5", M4_DIGIT(2))
47     float pbf_gain;
48 
49     // M4_NUMBER_DESC("pbf_add", "f32", M4_RANGE(0.0, 1023.0), "0.0", M4_DIGIT(2))
50     float pbf_add;
51 
52     // M4_NUMBER_DESC("pbf_ratio", "f32", M4_RANGE(0.0, 1.0), "0.5", M4_DIGIT(2))
53     float pbf_ratio;
54 
55     // M4_NUMBER_DESC("gaus_ratio", "f32", M4_RANGE(0.0, 1.0), "0.0", M4_DIGIT(2))
56     float gaus_ratio;
57 
58     // M4_NUMBER_DESC("sharp_ratio", "f32", M4_RANGE(0.0, 32.0), "0.5", M4_DIGIT(2))
59     float sharp_ratio;
60 
61 
62 
63     // M4_NUMBER_DESC("bf_gain", "f32", M4_RANGE(0.0, 2.0), "0.5", M4_DIGIT(2))
64     float bf_gain;
65     // M4_NUMBER_DESC("bf_add", "f32", M4_RANGE(0.0, 1023.0), "0.0", M4_DIGIT(2))
66     float bf_add;
67     // M4_NUMBER_DESC("bf_ratio", "f32", M4_RANGE(0.0, 1.0), "0.5", M4_DIGIT(2))
68     float bf_ratio;
69 
70 
71     // M4_ARRAY_DESC("hf_clip", "s16", M4_SIZE(1,8), M4_RANGE(0,1023), "[10, 20, 30, 56, 56, 56, 56, 30]", M4_DIGIT(0), M4_DYNAMIC(0))
72     int16_t hf_clip[RK_SHARP_V4_LUMA_POINT_NUM];
73     // M4_ARRAY_DESC("local_sharp_strength", "s16", M4_SIZE(1,8), M4_RANGE(0,1023), "[1023, 1023, 1023, 1023, 1023, 1023, 1023, 1023]", M4_DIGIT(0), M4_DYNAMIC(0))
74     int16_t local_sharp_strength[RK_SHARP_V4_LUMA_POINT_NUM];
75 
76 
77 
78     // M4_BOOL_DESC("kernel_sigma_enable", "1")
79     int kernel_sigma_enable;
80     // M4_ARRAY_DESC("prefilter_sigma", "f32", M4_SIZE(1,1), M4_RANGE(0,100), "[1.0]", M4_DIGIT(2), M4_DYNAMIC(0))
81     float prefilter_sigma;
82     // M4_ARRAY_DESC("hfBilateralFilter_sigma", "f32", M4_SIZE(1,1), M4_RANGE(0,100), "[1.0]", M4_DIGIT(2), M4_DYNAMIC(0))
83     float hfBilateralFilter_sigma;
84     // M4_ARRAY_DESC("GaussianFilter_sigma", "f32", M4_SIZE(1,1), M4_RANGE(0,100), "[1.0]", M4_DIGIT(2), M4_DYNAMIC(0))
85     float GaussianFilter_sigma;
86     // M4_ARRAY_DESC("GaussianFilter_radius", "f32", M4_SIZE(1,1), M4_RANGE(1,2), "[2.0]", M4_DIGIT(0), M4_DYNAMIC(0))
87     float GaussianFilter_radius;
88 
89 
90     // 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))
91     float prefilter_coeff[3];
92     // 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))
93     float GaussianFilter_coeff[6];
94     // 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))
95     float hfBilateralFilter_coeff[3];
96 
97 
98 
99 
100 
101 } RK_SHARP_Params_V4_Select_t;
102 
103 
104 
105 typedef struct Asharp4_ExpInfo_s {
106 
107     // M4_NUMBER_DESC("hdr_mode", "u8", M4_RANGE(0, 2), "0", M4_DIGIT(0))
108     int hdr_mode;
109     // M4_NUMBER_DESC("snr_mode", "s8", M4_RANGE(0, 2), "0", M4_DIGIT(0))
110     int   snr_mode;
111 
112     // M4_ARRAY_DESC("time", "f32", M4_SIZE(1,3), M4_RANGE(0, 1024), "0.01", M4_DIGIT(6))
113     float arTime[3];
114     // M4_ARRAY_DESC("again", "f32", M4_SIZE(1,3), M4_RANGE(0, 204800), "1", M4_DIGIT(3))
115     float arAGain[3];
116     // M4_ARRAY_DESC("dgain", "f32", M4_SIZE(1,3), M4_RANGE(0, 204800), "1", M4_DIGIT(3))
117     float arDGain[3];
118     // M4_ARRAY_DESC("iso", "u32", M4_SIZE(1,3), M4_RANGE(0, 204800), "1", M4_DIGIT(0))
119     int   arIso[3];
120 
121     // M4_NUMBER_DESC("isoLow", "u32", M4_RANGE(0, 204800), "50", M4_DIGIT(0))
122     int isoLow;
123     // M4_NUMBER_DESC("isoHigh", "u32", M4_RANGE(0, 204800), "50", M4_DIGIT(0))
124     int isoHigh;
125 
126     // M4_NUMBER_DESC("rawWidth", "s32", M4_RANGE(0, 65535), "0", M4_DIGIT(0))
127     int rawWidth;
128     // M4_NUMBER_DESC("rawHeight", "s32", M4_RANGE(0, 65535), "0", M4_DIGIT(0))
129     int rawHeight;
130 } Asharp4_ExpInfo_t;
131 
132 typedef struct rk_aiq_sharp_info_v4_s {
133     // M4_ARRAY_TABLE_DESC("sync", "array_table_ui", "none", "1")
134     rk_aiq_uapi_sync_t sync;
135     // M4_NUMBER_DESC("iso", "u32", M4_RANGE(0, 204800), "50", M4_DIGIT(0), "0", "0")
136     int iso;
137     // M4_ARRAY_TABLE_DESC("expo_info", "normal_ui_style", "none", "0", "0")
138     Asharp4_ExpInfo_t expo_info;
139 } rk_aiq_sharp_info_v4_t;
140 
141 RKAIQ_END_DECLARE
142 
143 #endif
144 
145