#include "auvnr/rk_aiq_uapi_auvnr_int_v1.h"
|
#include "auvnr/rk_aiq_types_auvnr_algo_prvt_v1.h"
|
#include "auvnr/rk_aiq_auvnr_algo_uvnr_v1.h"
|
|
|
#if 1
|
#define UVNR_CHROMA_SF_STRENGTH_MAX_PERCENT (50.0)
|
|
|
XCamReturn
|
rk_aiq_uapi_auvnr_SetAttrib(RkAiqAlgoContext *ctx,
|
rk_aiq_uvnr_attrib_v1_t *attr,
|
bool need_sync)
|
{
|
|
Auvnr_Context_V1_t* pCtx = (Auvnr_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_auvnr_GetAttrib(const RkAiqAlgoContext *ctx,
|
rk_aiq_uvnr_attrib_v1_t *attr)
|
{
|
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
attr->eMode = pCtx->eMode;
|
memcpy(&attr->stAuto, &pCtx->stAuto, sizeof(Auvnr_Auto_Attr_V1_t));
|
memcpy(&attr->stManual, &pCtx->stManual, sizeof(Auvnr_Manual_Attr_V1_t));
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|
|
XCamReturn
|
rk_aiq_uapi_auvnr_SetIQPara(RkAiqAlgoContext *ctx,
|
rk_aiq_uvnr_IQPara_v1_t *pPara,
|
bool need_sync)
|
{
|
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
|
pCtx->stUvnrCalib.enable = pPara->stUvnrPara.enable;
|
memcpy(pCtx->stUvnrCalib.version, pPara->stUvnrPara.version, sizeof(pPara->stUvnrPara.version));
|
for(int i=0; i<pCtx->stUvnrCalib.mode_num; i++){
|
pCtx->stUvnrCalib.mode_cell[i] = pPara->stUvnrPara.mode_cell[i];
|
}
|
pCtx->isIQParaUpdate = true;
|
|
#if(ANR_USE_JSON_PARA)
|
uvnrV1_calibdb_to_calibdbV2(&pCtx->stUvnrCalib, &pCtx->uvnr_v1, 0);
|
#endif
|
|
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|
|
|
XCamReturn
|
rk_aiq_uapi_auvnr_GetIQPara(RkAiqAlgoContext *ctx,
|
rk_aiq_uvnr_IQPara_v1_t *pPara)
|
{
|
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
#if(ANR_USE_JSON_PARA)
|
uvnrV1_calibdbV2_to_calibdb(&pCtx->uvnr_v1, &pCtx->stUvnrCalib, 0);
|
#endif
|
memset(&pPara->stUvnrPara, 0x00, sizeof(CalibDb_UVNR_t));
|
pPara->stUvnrPara.enable = pCtx->stUvnrCalib.enable;
|
memcpy(pPara->stUvnrPara.version, pCtx->stUvnrCalib.version, sizeof(pPara->stUvnrPara.version));
|
for(int i=0; i<pCtx->stUvnrCalib.mode_num; i++){
|
pPara->stUvnrPara.mode_cell[i] = pCtx->stUvnrCalib.mode_cell[i];
|
}
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|
|
|
XCamReturn
|
rk_aiq_uapi_auvnr_SetChromaSFStrength(const RkAiqAlgoContext *ctx,
|
float fPercent)
|
{
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
float fStrength = 1.0f;
|
float fMax = UVNR_CHROMA_SF_STRENGTH_MAX_PERCENT;
|
|
if(fPercent <= 0.5){
|
fStrength = fPercent /0.5;
|
}else{
|
fStrength = (fPercent - 0.5)*(fMax - 1) * 2 + 1;
|
}
|
|
pCtx->fChrom_SF_Strength = fStrength;
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|
|
|
|
XCamReturn
|
rk_aiq_uapi_auvnr_GetChromaSFStrength(const RkAiqAlgoContext *ctx,
|
float *pPercent)
|
{
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
float fStrength = 1.0f;
|
float fMax = UVNR_CHROMA_SF_STRENGTH_MAX_PERCENT;
|
|
fStrength = pCtx->fChrom_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_auvnr_SetJsonPara(RkAiqAlgoContext *ctx,
|
rk_aiq_uvnr_JsonPara_v1_t *pPara,
|
bool need_sync)
|
{
|
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
uvnr_calibdbV2_assign_v1(&pCtx->uvnr_v1, &pPara->uvnr_v1);
|
pCtx->isIQParaUpdate = true;
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|
|
|
|
XCamReturn
|
rk_aiq_uapi_auvnr_GetJsonPara(RkAiqAlgoContext *ctx,
|
rk_aiq_uvnr_JsonPara_v1_t *pPara)
|
{
|
|
Auvnr_Context_V1_t* pCtx = (Auvnr_Context_V1_t*)ctx;
|
|
uvnr_calibdbV2_assign_v1(&pPara->uvnr_v1, &pCtx->uvnr_v1);
|
|
return XCAM_RETURN_NO_ERROR;
|
}
|
|
|
#endif
|