/* * Copyright (c) 2019 Rockchip Corporation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #include "sample_comm.h" static void sample_acnr_usage() { printf("Usage : \n"); printf("\t 0) ACNR: get acnr attri on sync mode.\n"); printf("\t 1) ACNR: get acnr strength on sync mode.\n"); printf("\t 2) ACNR: set acnr attri auto on sync mode.\n"); printf("\t 3) ACNR: set acnr attri manual on sync mode.\n"); printf("\t 4) ACNR: set acnr attri reg value on sync mode.\n"); printf("\t 5) ACNR: set acnr strength max value 1.0 on sync mode, only on auto mode has effect.\n"); printf("\t 6) ACNR: set acnr strength min value 0.0 on sync mode, only on auto mode has effect.\n"); printf("\t 7) ACNR: set acnr strength med value 0.5 on sync mode, only on auto mode has effect.\n"); printf("\t 8) ACNR: set acnr attri to default vaule on sync mode.\n"); printf("\t a) ACNR: get acnr attri on async mode.\n"); printf("\t b) ACNR: get acnr strength on async mode.\n"); printf("\t c) ACNR: set acnr attri auto on async mode.\n"); printf("\t d) ACNR: set acnr attri manual on async mode.\n"); printf("\t e) ACNR: set acnr attri reg value on async mode.\n"); printf("\t f) ACNR: set acnr strength max value 1.0 on async mode, only on auto mode has effect.\n"); printf("\t g) ACNR: set acnr strength min value 0.0 on async mode, only on auto mode has effect.\n"); printf("\t h) ACNR: set acnr strength med value 0.5 on async mode, only on auto mode has effect.\n"); printf("\t i) ACNR: set acnr attri to default vaule on async mode.\n"); printf("\t q) ACNR: press key q or Q to quit.\n"); } void sample_print_acnr_info(const void *arg) { printf ("enter ACNR modult test!\n"); } XCamReturn sample_acnr_module (const void *arg) { int key = -1; CLEAR(); XCamReturn ret = XCAM_RETURN_NO_ERROR; const demo_context_t *demo_ctx = (demo_context_t *)arg; const rk_aiq_sys_ctx_t* ctx ; if(demo_ctx->camGroup) { ctx = (const rk_aiq_sys_ctx_t*)(demo_ctx->camgroup_ctx); printf("##################group !!!!########################\n"); } else { ctx = (const rk_aiq_sys_ctx_t*)(demo_ctx->aiq_ctx); printf("##################sigle !!!!########################\n"); } if (ctx == nullptr) { ERR ("%s, ctx is nullptr\n", __FUNCTION__); return XCAM_RETURN_ERROR_PARAM; } rk_aiq_cnr_attrib_v2_t default_cnrV2_attr; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &default_cnrV2_attr); printf("get acnr v2 default attri ret:%d \n\n", ret); do { sample_acnr_usage (); key = getchar (); while (key == '\n' || key == '\r') key = getchar (); printf ("\n"); switch (key) { case '0': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, cnrV2_attr.sync.done); } break; case '1': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, cnrV2_Strenght.percent, cnrV2_Strenght.sync.done); } break; case '2': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; cnrV2_attr.eMode = ACNRV2_OP_MODE_AUTO; cnrV2_attr.stAuto.stParams.enable = 1; for(int i = 0; i < RK_CNR_V2_MAX_ISO_NUM; i++) { cnrV2_attr.stAuto.stParams.iso[i] = 50 * pow(2, i); cnrV2_attr.stAuto.stParams.hf_bypass[i] = 0; cnrV2_attr.stAuto.stParams.lf_bypass[i] = 0; cnrV2_attr.stAuto.stParams.global_gain[i] = 1.0; cnrV2_attr.stAuto.stParams.global_gain_alpha[i] = 0.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][0] = 256.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][1] = 256.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][2] = 128.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][3] = 85.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][4] = 64.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][5] = 43.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][6] = 32.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][7] = 21.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][8] = 16.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][9] = 8.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][10] = 4.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][11] = 1.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][12] = 1.0; cnrV2_attr.stAuto.stParams.color_sat_adj[i] = 40.0; cnrV2_attr.stAuto.stParams.color_sat_adj_alpha[i] = 0.8; cnrV2_attr.stAuto.stParams.hf_spikes_reducion_strength[i] = 0.5; cnrV2_attr.stAuto.stParams.hf_denoise_strength[i] = 16.0; cnrV2_attr.stAuto.stParams.hf_color_sat[i] = 1.5; cnrV2_attr.stAuto.stParams.hf_denoise_alpha[i] = 0.0; cnrV2_attr.stAuto.stParams.hf_bf_wgt_clip[i] = 0; cnrV2_attr.stAuto.stParams.thumb_spikes_reducion_strength[i] = 0.5; cnrV2_attr.stAuto.stParams.thumb_denoise_strength[i] = 16.0; cnrV2_attr.stAuto.stParams.thumb_color_sat[i] = 4.0; cnrV2_attr.stAuto.stParams.lf_denoise_strength[i] = 16.0; cnrV2_attr.stAuto.stParams.lf_color_sat[i] = 4.0; cnrV2_attr.stAuto.stParams.lf_denoise_alpha[i] = 0.5; cnrV2_attr.stAuto.stParams.kernel_5x5[0] = 1.0; cnrV2_attr.stAuto.stParams.kernel_5x5[1] = 0.8825; cnrV2_attr.stAuto.stParams.kernel_5x5[2] = 0.7788; cnrV2_attr.stAuto.stParams.kernel_5x5[3] = 0.6065; cnrV2_attr.stAuto.stParams.kernel_5x5[4] = 0.3679; } ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &cnrV2_attr); printf("set acnr attri auto ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case '3': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; cnrV2_attr.eMode = ACNRV2_OP_MODE_MANUAL; cnrV2_attr.stManual.stSelect.enable = 1; cnrV2_attr.stManual.stSelect.hf_bypass = 0; cnrV2_attr.stManual.stSelect.lf_bypass = 0; cnrV2_attr.stManual.stSelect.global_gain = 1.0; cnrV2_attr.stManual.stSelect.global_gain_alpha = 0.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[0] = 256.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[1] = 256.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[2] = 128.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[3] = 85.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[4] = 64.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[5] = 43.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[6] = 32.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[7] = 21.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[8] = 16.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[9] = 8.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[10] = 4.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[11] = 1.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[12] = 1.0; cnrV2_attr.stManual.stSelect.color_sat_adj = 40.0; cnrV2_attr.stManual.stSelect.color_sat_adj_alpha = 0.8; cnrV2_attr.stManual.stSelect.hf_spikes_reducion_strength = 0.5; cnrV2_attr.stManual.stSelect.hf_denoise_strength = 16.0; cnrV2_attr.stManual.stSelect.hf_color_sat = 1.5; cnrV2_attr.stManual.stSelect.hf_denoise_alpha = 0.0; cnrV2_attr.stManual.stSelect.hf_bf_wgt_clip = 0; cnrV2_attr.stManual.stSelect.thumb_spikes_reducion_strength = 0.5; cnrV2_attr.stManual.stSelect.thumb_denoise_strength = 16.0; cnrV2_attr.stManual.stSelect.thumb_color_sat = 4.0; cnrV2_attr.stManual.stSelect.lf_denoise_strength = 16.0; cnrV2_attr.stManual.stSelect.lf_color_sat = 4.0; cnrV2_attr.stManual.stSelect.lf_denoise_alpha = 0.5; cnrV2_attr.stManual.stSelect.kernel_5x5[0] = 1.0; cnrV2_attr.stManual.stSelect.kernel_5x5[1] = 0.8825; cnrV2_attr.stManual.stSelect.kernel_5x5[2] = 0.7788; cnrV2_attr.stManual.stSelect.kernel_5x5[3] = 0.6065; cnrV2_attr.stManual.stSelect.kernel_5x5[4] = 0.3679; ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &cnrV2_attr); printf("set cnr v2 attri manual ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case '4': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; cnrV2_attr.eMode = ACNRV2_OP_MODE_REG_MANUAL; //ISP_CNR_2800_CTR cnrV2_attr.stManual.stFix.cnr_thumb_mix_cur_en = 0; cnrV2_attr.stManual.stFix.cnr_lq_bila_bypass = 0; cnrV2_attr.stManual.stFix.cnr_hq_bila_bypass = 0; cnrV2_attr.stManual.stFix.cnr_exgain_bypass = 0; cnrV2_attr.stManual.stFix.cnr_en_i = 1; // ISP_CNR_2800_EXGAIN cnrV2_attr.stManual.stFix.cnr_global_gain_alpha = 0x0; cnrV2_attr.stManual.stFix.cnr_global_gain = 0x80; // ISP_CNR_2800_GAIN_PARA cnrV2_attr.stManual.stFix.cnr_gain_iso = 0x16; cnrV2_attr.stManual.stFix.cnr_gain_offset = 0x0c; cnrV2_attr.stManual.stFix.cnr_gain_1sigma = 0x3c; // ISP_CNR_2800_GAIN_UV_PARA cnrV2_attr.stManual.stFix.cnr_gain_uvgain1 = 0x40; cnrV2_attr.stManual.stFix.cnr_gain_uvgain0 = 0x30; // ISP_CNR_2800_LMED3 cnrV2_attr.stManual.stFix.cnr_lmed3_alpha = 0x03; // ISP_CNR_2800_LBF5_GAIN cnrV2_attr.stManual.stFix.cnr_lbf5_gain_y = 0x1; cnrV2_attr.stManual.stFix.cnr_lbf5_gain_c = 0x02; // ISP_CNR_2800_LBF5_WEITD0_4 cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[0] = 0x80; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[1] = 0x70; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[2] = 0x63; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[3] = 0x4d; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[4] = 0x2f; // ISP_CNR_2800_HMED3 cnrV2_attr.stManual.stFix.cnr_hmed3_alpha = 0x03; // ISP_CNR_2800_HBF5 cnrV2_attr.stManual.stFix.cnr_hbf5_weit_src = 0x0f; cnrV2_attr.stManual.stFix.cnr_hbf5_min_wgt = 0x00; cnrV2_attr.stManual.stFix.cnr_hbf5_sigma = 0x0438; // ISP_CNR_2800_LBF3 cnrV2_attr.stManual.stFix.cnr_lbf5_weit_src = 0xff; cnrV2_attr.stManual.stFix.cnr_lbf3_sigma = 0x0438; //ISP_CNR_2800_SIGMA0-SIGMA3 cnrV2_attr.stManual.stFix.cnr_sigma_y[0] = 0xff; cnrV2_attr.stManual.stFix.cnr_sigma_y[1] = 0x80; cnrV2_attr.stManual.stFix.cnr_sigma_y[2] = 0x55; cnrV2_attr.stManual.stFix.cnr_sigma_y[3] = 0x40; cnrV2_attr.stManual.stFix.cnr_sigma_y[4] = 0x2b; cnrV2_attr.stManual.stFix.cnr_sigma_y[5] = 0x20; cnrV2_attr.stManual.stFix.cnr_sigma_y[6] = 0x15; cnrV2_attr.stManual.stFix.cnr_sigma_y[7] = 0x10; cnrV2_attr.stManual.stFix.cnr_sigma_y[8] = 0x08; cnrV2_attr.stManual.stFix.cnr_sigma_y[9] = 0x04; cnrV2_attr.stManual.stFix.cnr_sigma_y[10] = 0x02; cnrV2_attr.stManual.stFix.cnr_sigma_y[11] = 0x01; cnrV2_attr.stManual.stFix.cnr_sigma_y[12] = 0x01; ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &cnrV2_attr); printf("set cnr v2 attri manual ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case '5': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; cnrV2_Strenght.strength_enable = true; cnrV2_Strenght.percent = 1.0; ret = rk_aiq_user_api2_acnrV2_SetStrength(ctx, &cnrV2_Strenght); printf("Set acnr v2 set streangth ret:%d strength:%f \n\n", ret, cnrV2_Strenght.percent); rk_aiq_cnr_strength_v2_t get_cnrV2_Strenght; get_cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &get_cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, get_cnrV2_Strenght.percent, get_cnrV2_Strenght.sync.done); } break; case '6': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; cnrV2_Strenght.strength_enable = true; cnrV2_Strenght.percent = 0.0; ret = rk_aiq_user_api2_acnrV2_SetStrength(ctx, &cnrV2_Strenght); printf("Set acnr v2 set streangth ret:%d strength:%f \n\n", ret, cnrV2_Strenght.percent); rk_aiq_cnr_strength_v2_t get_cnrV2_Strenght; get_cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &get_cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, get_cnrV2_Strenght.percent, get_cnrV2_Strenght.sync.done); } break; case '7': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; cnrV2_Strenght.strength_enable = true; cnrV2_Strenght.percent = 0.5; ret = rk_aiq_user_api2_acnrV2_SetStrength(ctx, &cnrV2_Strenght); printf("Set acnr v2 set streangth ret:%d strength:%f \n\n", ret, cnrV2_Strenght.percent); rk_aiq_cnr_strength_v2_t get_cnrV2_Strenght; get_cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &get_cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, get_cnrV2_Strenght.percent, get_cnrV2_Strenght.sync.done); } break; case '8': if (CHECK_ISP_HW_V30()) { default_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &default_cnrV2_attr); printf("Set acnr v2 set default attri ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_SYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case 'a': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, cnrV2_attr.sync.done); } break; case 'b': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, cnrV2_Strenght.percent, cnrV2_Strenght.sync.done); } break; case 'c': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; cnrV2_attr.eMode = ACNRV2_OP_MODE_AUTO; cnrV2_attr.stAuto.stParams.enable = 1; for(int i = 0; i < RK_CNR_V2_MAX_ISO_NUM; i++) { cnrV2_attr.stAuto.stParams.iso[i] = 50 * pow(2, i); cnrV2_attr.stAuto.stParams.hf_bypass[i] = 0; cnrV2_attr.stAuto.stParams.lf_bypass[i] = 0; cnrV2_attr.stAuto.stParams.global_gain[i] = 1.0; cnrV2_attr.stAuto.stParams.global_gain_alpha[i] = 0.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][0] = 256.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][1] = 256.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][2] = 128.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][3] = 85.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][4] = 64.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][5] = 43.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][6] = 32.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][7] = 21.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][8] = 16.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][9] = 8.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][10] = 4.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][11] = 1.0; cnrV2_attr.stAuto.stParams.gain_adj_strength_ratio[i][12] = 1.0; cnrV2_attr.stAuto.stParams.color_sat_adj[i] = 40.0; cnrV2_attr.stAuto.stParams.color_sat_adj_alpha[i] = 0.8; cnrV2_attr.stAuto.stParams.hf_spikes_reducion_strength[i] = 0.5; cnrV2_attr.stAuto.stParams.hf_denoise_strength[i] = 16.0; cnrV2_attr.stAuto.stParams.hf_color_sat[i] = 1.5; cnrV2_attr.stAuto.stParams.hf_denoise_alpha[i] = 0.0; cnrV2_attr.stAuto.stParams.hf_bf_wgt_clip[i] = 0; cnrV2_attr.stAuto.stParams.thumb_spikes_reducion_strength[i] = 0.5; cnrV2_attr.stAuto.stParams.thumb_denoise_strength[i] = 16.0; cnrV2_attr.stAuto.stParams.thumb_color_sat[i] = 4.0; cnrV2_attr.stAuto.stParams.lf_denoise_strength[i] = 16.0; cnrV2_attr.stAuto.stParams.lf_color_sat[i] = 4.0; cnrV2_attr.stAuto.stParams.lf_denoise_alpha[i] = 0.5; cnrV2_attr.stAuto.stParams.kernel_5x5[0] = 1.0; cnrV2_attr.stAuto.stParams.kernel_5x5[1] = 0.8825; cnrV2_attr.stAuto.stParams.kernel_5x5[2] = 0.7788; cnrV2_attr.stAuto.stParams.kernel_5x5[3] = 0.6065; cnrV2_attr.stAuto.stParams.kernel_5x5[4] = 0.3679; } ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &cnrV2_attr); printf("set acnr attri auto ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case 'd': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; cnrV2_attr.eMode = ACNRV2_OP_MODE_MANUAL; cnrV2_attr.stManual.stSelect.enable = 1; cnrV2_attr.stManual.stSelect.hf_bypass = 0; cnrV2_attr.stManual.stSelect.lf_bypass = 0; cnrV2_attr.stManual.stSelect.global_gain = 1.0; cnrV2_attr.stManual.stSelect.global_gain_alpha = 0.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[0] = 256.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[1] = 256.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[2] = 128.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[3] = 85.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[4] = 64.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[5] = 43.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[6] = 32.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[7] = 21.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[8] = 16.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[9] = 8.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[10] = 4.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[11] = 1.0; cnrV2_attr.stManual.stSelect.gain_adj_strength_ratio[12] = 1.0; cnrV2_attr.stManual.stSelect.color_sat_adj = 40.0; cnrV2_attr.stManual.stSelect.color_sat_adj_alpha = 0.8; cnrV2_attr.stManual.stSelect.hf_spikes_reducion_strength = 0.5; cnrV2_attr.stManual.stSelect.hf_denoise_strength = 16.0; cnrV2_attr.stManual.stSelect.hf_color_sat = 1.5; cnrV2_attr.stManual.stSelect.hf_denoise_alpha = 0.0; cnrV2_attr.stManual.stSelect.hf_bf_wgt_clip = 0; cnrV2_attr.stManual.stSelect.thumb_spikes_reducion_strength = 0.5; cnrV2_attr.stManual.stSelect.thumb_denoise_strength = 16.0; cnrV2_attr.stManual.stSelect.thumb_color_sat = 4.0; cnrV2_attr.stManual.stSelect.lf_denoise_strength = 16.0; cnrV2_attr.stManual.stSelect.lf_color_sat = 4.0; cnrV2_attr.stManual.stSelect.lf_denoise_alpha = 0.5; cnrV2_attr.stManual.stSelect.kernel_5x5[0] = 1.0; cnrV2_attr.stManual.stSelect.kernel_5x5[1] = 0.8825; cnrV2_attr.stManual.stSelect.kernel_5x5[2] = 0.7788; cnrV2_attr.stManual.stSelect.kernel_5x5[3] = 0.6065; cnrV2_attr.stManual.stSelect.kernel_5x5[4] = 0.3679; ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &cnrV2_attr); printf("set cnr v2 attri manual ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case 'e': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_attrib_v2_t cnrV2_attr; cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &cnrV2_attr); cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; cnrV2_attr.eMode = ACNRV2_OP_MODE_REG_MANUAL; //ISP_CNR_2800_CTR cnrV2_attr.stManual.stFix.cnr_thumb_mix_cur_en = 0; cnrV2_attr.stManual.stFix.cnr_lq_bila_bypass = 0; cnrV2_attr.stManual.stFix.cnr_hq_bila_bypass = 0; cnrV2_attr.stManual.stFix.cnr_exgain_bypass = 0; cnrV2_attr.stManual.stFix.cnr_en_i = 1; // ISP_CNR_2800_EXGAIN cnrV2_attr.stManual.stFix.cnr_global_gain_alpha = 0x0; cnrV2_attr.stManual.stFix.cnr_global_gain = 0x80; // ISP_CNR_2800_GAIN_PARA cnrV2_attr.stManual.stFix.cnr_gain_iso = 0x16; cnrV2_attr.stManual.stFix.cnr_gain_offset = 0x0c; cnrV2_attr.stManual.stFix.cnr_gain_1sigma = 0x3c; // ISP_CNR_2800_GAIN_UV_PARA cnrV2_attr.stManual.stFix.cnr_gain_uvgain1 = 0x40; cnrV2_attr.stManual.stFix.cnr_gain_uvgain0 = 0x30; // ISP_CNR_2800_LMED3 cnrV2_attr.stManual.stFix.cnr_lmed3_alpha = 0x03; // ISP_CNR_2800_LBF5_GAIN cnrV2_attr.stManual.stFix.cnr_lbf5_gain_y = 0x1; cnrV2_attr.stManual.stFix.cnr_lbf5_gain_c = 0x02; // ISP_CNR_2800_LBF5_WEITD0_4 cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[0] = 0x80; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[1] = 0x70; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[2] = 0x63; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[3] = 0x4d; cnrV2_attr.stManual.stFix.cnr_lbf5_weit_d[4] = 0x2f; // ISP_CNR_2800_HMED3 cnrV2_attr.stManual.stFix.cnr_hmed3_alpha = 0x03; // ISP_CNR_2800_HBF5 cnrV2_attr.stManual.stFix.cnr_hbf5_weit_src = 0x0f; cnrV2_attr.stManual.stFix.cnr_hbf5_min_wgt = 0x00; cnrV2_attr.stManual.stFix.cnr_hbf5_sigma = 0x0438; // ISP_CNR_2800_LBF3 cnrV2_attr.stManual.stFix.cnr_lbf5_weit_src = 0xff; cnrV2_attr.stManual.stFix.cnr_lbf3_sigma = 0x0438; //ISP_CNR_2800_SIGMA0-SIGMA3 cnrV2_attr.stManual.stFix.cnr_sigma_y[0] = 0xff; cnrV2_attr.stManual.stFix.cnr_sigma_y[1] = 0x80; cnrV2_attr.stManual.stFix.cnr_sigma_y[2] = 0x55; cnrV2_attr.stManual.stFix.cnr_sigma_y[3] = 0x40; cnrV2_attr.stManual.stFix.cnr_sigma_y[4] = 0x2b; cnrV2_attr.stManual.stFix.cnr_sigma_y[5] = 0x20; cnrV2_attr.stManual.stFix.cnr_sigma_y[6] = 0x15; cnrV2_attr.stManual.stFix.cnr_sigma_y[7] = 0x10; cnrV2_attr.stManual.stFix.cnr_sigma_y[8] = 0x08; cnrV2_attr.stManual.stFix.cnr_sigma_y[9] = 0x04; cnrV2_attr.stManual.stFix.cnr_sigma_y[10] = 0x02; cnrV2_attr.stManual.stFix.cnr_sigma_y[11] = 0x01; cnrV2_attr.stManual.stFix.cnr_sigma_y[12] = 0x01; ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &cnrV2_attr); printf("set cnr v2 attri manual ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; case 'f': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; cnrV2_Strenght.strength_enable = true; cnrV2_Strenght.percent = 1.0; ret = rk_aiq_user_api2_acnrV2_SetStrength(ctx, &cnrV2_Strenght); printf("Set acnr v2 set streangth ret:%d strength:%f \n\n", ret, cnrV2_Strenght.percent); rk_aiq_cnr_strength_v2_t get_cnrV2_Strenght; get_cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &get_cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, get_cnrV2_Strenght.percent, get_cnrV2_Strenght.sync.done); } break; case 'g': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; cnrV2_Strenght.strength_enable = true; cnrV2_Strenght.percent = 0.0; ret = rk_aiq_user_api2_acnrV2_SetStrength(ctx, &cnrV2_Strenght); printf("Set acnr v2 set streangth ret:%d strength:%f \n\n", ret, cnrV2_Strenght.percent); rk_aiq_cnr_strength_v2_t get_cnrV2_Strenght; get_cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &get_cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, get_cnrV2_Strenght.percent, get_cnrV2_Strenght.sync.done); } break; case 'h': if (CHECK_ISP_HW_V30()) { rk_aiq_cnr_strength_v2_t cnrV2_Strenght; cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; cnrV2_Strenght.strength_enable = true; cnrV2_Strenght.percent = 0.5; ret = rk_aiq_user_api2_acnrV2_SetStrength(ctx, &cnrV2_Strenght); printf("Set acnr v2 set streangth ret:%d strength:%f \n\n", ret, cnrV2_Strenght.percent); rk_aiq_cnr_strength_v2_t get_cnrV2_Strenght; get_cnrV2_Strenght.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetStrength(ctx, &get_cnrV2_Strenght); printf("get acnr v2 attri ret:%d strength:%f done:%d \n\n", ret, get_cnrV2_Strenght.percent, get_cnrV2_Strenght.sync.done); } break; case 'i': if (CHECK_ISP_HW_V30()) { default_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_SetAttrib(ctx, &default_cnrV2_attr); printf("Set acnr v2 set default attri ret:%d \n\n", ret); rk_aiq_cnr_attrib_v2_t get_cnrV2_attr; get_cnrV2_attr.sync.sync_mode = RK_AIQ_UAPI_MODE_ASYNC; ret = rk_aiq_user_api2_acnrV2_GetAttrib(ctx, &get_cnrV2_attr); printf("get acnr v2 attri ret:%d done:%d\n\n", ret, get_cnrV2_attr.sync.done); } break; default: printf("not support test\n\n"); break; } } while (key != 'q' && key != 'Q'); return ret; }