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