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