#include "arawnr/rk_aiq_uapi_abayernr_int_v1.h" 
 | 
#include "bayernr_xml2json_v1.h" 
 | 
#include "arawnr/rk_aiq_types_abayernr_algo_prvt_v1.h" 
 | 
#include "arawnr/rk_aiq_abayernr_algo_bayernr_v1.h" 
 | 
  
 | 
  
 | 
  
 | 
#if 1 
 | 
#define BAYERNR_RAWNR_SF_STRENGTH_MAX_PERCENT (80.0) 
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_SetAttrib_v1(RkAiqAlgoContext *ctx, 
 | 
                                  rk_aiq_bayernr_attrib_v1_t *attr, 
 | 
                                  bool need_sync) 
 | 
{ 
 | 
  
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
  
 | 
    pCtx->eMode = attr->eMode; 
 | 
    pCtx->stAuto = attr->stAuto; 
 | 
    pCtx->stManual = attr->stManual; 
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_GetAttrib_v1(const RkAiqAlgoContext *ctx, 
 | 
                                  rk_aiq_bayernr_attrib_v1_t *attr) 
 | 
{ 
 | 
  
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
  
 | 
    attr->eMode = pCtx->eMode; 
 | 
    memcpy(&attr->stAuto, &pCtx->stAuto, sizeof(Abayernr_Auto_Attr_V1_t)); 
 | 
    memcpy(&attr->stManual, &pCtx->stManual, sizeof(Abayernr_Manual_Attr_V1_t)); 
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_SetIQPara_v1(RkAiqAlgoContext *ctx, 
 | 
                                  rk_aiq_bayernr_IQPara_V1_t *pPara, 
 | 
                                  bool need_sync) 
 | 
{ 
 | 
  
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
    CalibDb_BayerNr_2_t Calibdb_2; 
 | 
  
 | 
    printf("%s:%d\n", __FUNCTION__, __LINE__); 
 | 
    if(pPara != NULL && pCtx != NULL) { 
 | 
        memset(&Calibdb_2, 0x00, sizeof(CalibDb_BayerNr_2_t)); 
 | 
        Calibdb_2.mode_num = sizeof(pPara->stBayernrPara.mode_cell) / sizeof(CalibDb_BayerNr_ModeCell_t); 
 | 
        Calibdb_2.mode_cell = (CalibDb_BayerNr_ModeCell_t *)malloc(Calibdb_2.mode_num * sizeof(CalibDb_BayerNr_ModeCell_t)); 
 | 
        Calibdb_2.enable = pPara->stBayernrPara.enable; 
 | 
        memcpy(Calibdb_2.version, pPara->stBayernrPara.version, sizeof(pPara->stBayernrPara.version)); 
 | 
        for(int i = 0; i < Calibdb_2.mode_num; i++) { 
 | 
            Calibdb_2.mode_cell[i] = pPara->stBayernrPara.mode_cell[i]; 
 | 
        } 
 | 
        printf("%s:%d\n", __FUNCTION__, __LINE__); 
 | 
#if ABAYERNR_USE_JSON_FILE_V1 
 | 
        bayernrV1_calibdb_to_calibdbV2(&Calibdb_2, &pCtx->bayernr_v1, 0); 
 | 
#else 
 | 
        pCtx->stBayernrCalib.enable = Calibdb_2.enable; 
 | 
        memcpy(pCtx->stBayernrCalib.version, Calibdb_2.version, sizeof(Calibdb_2.version)); 
 | 
        for(int i = 0; i < Calibdb_2.mode_num && i < pCtx->stBayernrCalib.mode_num; i++) { 
 | 
            pCtx->stBayernrCalib.mode_cell[i] = Calibdb_2.mode_cell[i]; 
 | 
        } 
 | 
#endif 
 | 
        pCtx->isIQParaUpdate = true; 
 | 
        printf("%s:%d\n", __FUNCTION__, __LINE__); 
 | 
        free(Calibdb_2.mode_cell); 
 | 
    } 
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_GetIQPara_v1(RkAiqAlgoContext *ctx, 
 | 
                                  rk_aiq_bayernr_IQPara_V1_t *pPara) 
 | 
{ 
 | 
  
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
    CalibDb_BayerNr_2_t Calibdb_2; 
 | 
  
 | 
    if(pPara != NULL && pCtx != NULL) { 
 | 
        memset(&Calibdb_2, 0x00, sizeof(CalibDb_BayerNr_2_t)); 
 | 
        Calibdb_2.mode_num = sizeof(pPara->stBayernrPara.mode_cell) / sizeof(CalibDb_BayerNr_ModeCell_t); 
 | 
        Calibdb_2.mode_cell = (CalibDb_BayerNr_ModeCell_t *)malloc(Calibdb_2.mode_num * sizeof(CalibDb_BayerNr_ModeCell_t)); 
 | 
  
 | 
        printf("%s:%d\n", __FUNCTION__, __LINE__); 
 | 
#if(ABAYERNR_USE_JSON_FILE_V1) 
 | 
        bayernrV1_calibdbV2_to_calibdb(&pCtx->bayernr_v1, &Calibdb_2, 0); 
 | 
#else 
 | 
        Calibdb_2.enable = pCtx->stBayernrCalib.enable; 
 | 
        memcpy(Calibdb_2.version, pCtx->stBayernrCalib.version, sizeof(pPara->stBayernrPara.version)); 
 | 
        for(int i = 0; i < Calibdb_2.mode_num && i < pCtx->stBayernrCalib.mode_num; i++) { 
 | 
            Calibdb_2.mode_cell[i] = pCtx->stBayernrCalib.mode_cell[i]; 
 | 
        } 
 | 
#endif 
 | 
  
 | 
        printf("%s:%d\n", __FUNCTION__, __LINE__); 
 | 
        memset(&pPara->stBayernrPara, 0x00, sizeof(CalibDb_BayerNr_t)); 
 | 
        pPara->stBayernrPara.enable = Calibdb_2.enable; 
 | 
        memcpy(pPara->stBayernrPara.version, Calibdb_2.version, sizeof(Calibdb_2.version)); 
 | 
        for(int i = 0; i < Calibdb_2.mode_num && i < CALIBDB_MAX_MODE_NUM; i++) { 
 | 
            pPara->stBayernrPara.mode_cell[i] = Calibdb_2.mode_cell[i]; 
 | 
        } 
 | 
  
 | 
        free(Calibdb_2.mode_cell); 
 | 
        printf("%s:%d\n", __FUNCTION__, __LINE__); 
 | 
    } 
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_SetRawnrSFStrength_v1(const RkAiqAlgoContext *ctx, 
 | 
        float fPercent) 
 | 
{ 
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
  
 | 
    float fStrength = 1.0; 
 | 
    float fMax = BAYERNR_RAWNR_SF_STRENGTH_MAX_PERCENT; 
 | 
  
 | 
    if(fPercent <= 0.5) { 
 | 
        fStrength =  fPercent / 0.5; 
 | 
    } else { 
 | 
        fStrength = (fPercent - 0.5) * (fMax - 1) * 2 + 1; 
 | 
    } 
 | 
  
 | 
    pCtx->fRawnr_SF_Strength = fStrength; 
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_GetRawnrSFStrength_v1(const RkAiqAlgoContext *ctx, 
 | 
        float *pPercent) 
 | 
{ 
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
  
 | 
    float fStrength = 1.0f; 
 | 
    float fMax = BAYERNR_RAWNR_SF_STRENGTH_MAX_PERCENT; 
 | 
  
 | 
    fStrength = pCtx->fRawnr_SF_Strength; 
 | 
  
 | 
  
 | 
    if(fStrength <= 1) { 
 | 
        *pPercent = fStrength * 0.5; 
 | 
    } else { 
 | 
        *pPercent = (fStrength - 1) / ((fMax - 1) * 2) + 0.5; 
 | 
    } 
 | 
  
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
  
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_SetJsonPara_v1(RkAiqAlgoContext *ctx, 
 | 
                                    rk_aiq_bayernr_JsonPara_V1_t *pPara, 
 | 
                                    bool need_sync) 
 | 
{ 
 | 
  
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
  
 | 
    if(pCtx != NULL && pPara != NULL) { 
 | 
#if ABAYERNR_USE_JSON_FILE_V1 
 | 
        bayernrV1_calibdbV2_assign(&pCtx->bayernr_v1, &pPara->bayernr_v1); 
 | 
        pCtx->isIQParaUpdate = true; 
 | 
#endif 
 | 
    } 
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
  
 | 
XCamReturn 
 | 
rk_aiq_uapi_abayernr_GetJsonPara_v1(RkAiqAlgoContext *ctx, 
 | 
                                    rk_aiq_bayernr_JsonPara_V1_t *pPara) 
 | 
{ 
 | 
  
 | 
    Abayernr_Context_V1_t* pCtx = (Abayernr_Context_V1_t*)ctx; 
 | 
  
 | 
    if(pCtx != NULL && pPara != NULL) { 
 | 
#if ABAYERNR_USE_JSON_FILE_V1 
 | 
        bayernrV1_calibdbV2_assign(&pPara->bayernr_v1, &pCtx->bayernr_v1); 
 | 
#endif 
 | 
    } 
 | 
  
 | 
    return XCAM_RETURN_NO_ERROR; 
 | 
} 
 | 
  
 | 
  
 | 
#endif 
 |