fix[mpp_enc_cfg]: Add lambda_idx_i and lambda_idx_p

Signed-off-by: toby.zhang <toby.zhang@rock-chips.com>
Change-Id: Id83274ae46250fb6287bdf8c8a8bf0d6f3d2fda5
This commit is contained in:
toby.zhang
2025-04-05 10:02:35 +08:00
committed by Herman Chen
parent dceef49597
commit cea5507d3f
3 changed files with 38 additions and 6 deletions

View File

@@ -616,18 +616,19 @@ MPP_RET test_mpp_enc_cfg_setup(MpiEncMultiCtxInfo *info)
} }
/* setup fine tuning paramters */ /* setup fine tuning paramters */
mpp_enc_cfg_set_s32(cfg, "tune:speed", cmd->speed);
mpp_enc_cfg_set_s32(cfg, "tune:anti_flicker_str", p->anti_flicker_str); mpp_enc_cfg_set_s32(cfg, "tune:anti_flicker_str", p->anti_flicker_str);
mpp_enc_cfg_set_s32(cfg, "tune:atr_str_i", p->atr_str_i); mpp_enc_cfg_set_s32(cfg, "tune:atr_str_i", p->atr_str_i);
mpp_enc_cfg_set_s32(cfg, "tune:atr_str_p", p->atr_str_p); mpp_enc_cfg_set_s32(cfg, "tune:atr_str_p", p->atr_str_p);
mpp_enc_cfg_set_s32(cfg, "tune:atl_str", p->atl_str); mpp_enc_cfg_set_s32(cfg, "tune:atl_str", p->atl_str);
mpp_enc_cfg_set_s32(cfg, "tune:sao_str_i", p->sao_str_i);
mpp_enc_cfg_set_s32(cfg, "tune:sao_str_p", p->sao_str_p);
mpp_enc_cfg_set_s32(cfg, "tune:scene_mode", p->scene_mode);
mpp_enc_cfg_set_s32(cfg, "tune:deblur_en", cmd->deblur_en); mpp_enc_cfg_set_s32(cfg, "tune:deblur_en", cmd->deblur_en);
mpp_enc_cfg_set_s32(cfg, "tune:deblur_str", cmd->deblur_str); mpp_enc_cfg_set_s32(cfg, "tune:deblur_str", cmd->deblur_str);
mpp_enc_cfg_set_s32(cfg, "tune:sao_str_i", p->sao_str_i);
mpp_enc_cfg_set_s32(cfg, "tune:sao_str_p", p->sao_str_p);
mpp_enc_cfg_set_s32(cfg, "tune:lambda_idx_p", cmd->lambda_idx_p);
mpp_enc_cfg_set_s32(cfg, "tune:lambda_idx_i", cmd->lambda_idx_i);
mpp_enc_cfg_set_s32(cfg, "tune:rc_container", cmd->rc_container); mpp_enc_cfg_set_s32(cfg, "tune:rc_container", cmd->rc_container);
mpp_enc_cfg_set_s32(cfg, "tune:scene_mode", p->scene_mode);
mpp_enc_cfg_set_s32(cfg, "tune:speed", cmd->speed);
mpp_enc_cfg_set_s32(cfg, "tune:vmaf_opt", 0); mpp_enc_cfg_set_s32(cfg, "tune:vmaf_opt", 0);
/* setup hardware specified parameters */ /* setup hardware specified parameters */

View File

@@ -652,6 +652,32 @@ RK_S32 mpi_enc_opt_bias_p(void *ctx, const char *next)
return 0; return 0;
} }
RK_S32 mpi_enc_opt_lmd(void *ctx, const char *next)
{
MpiEncTestArgs *cmd = (MpiEncTestArgs *)ctx;
if (next) {
cmd->lambda_idx_p = atoi(next);
return 1;
}
mpp_err("invalid lambda idx\n");
return 0;
}
RK_S32 mpi_enc_opt_lmdi(void *ctx, const char *next)
{
MpiEncTestArgs *cmd = (MpiEncTestArgs *)ctx;
if (next) {
cmd->lambda_idx_i = atoi(next);
return 1;
}
mpp_err("invalid intra lambda idx\n");
return 0;
}
RK_S32 mpi_enc_opt_speed(void *ctx, const char *next) RK_S32 mpi_enc_opt_speed(void *ctx, const char *next)
{ {
MpiEncTestArgs *cmd = (MpiEncTestArgs *)ctx; MpiEncTestArgs *cmd = (MpiEncTestArgs *)ctx;
@@ -723,7 +749,9 @@ static MppOptInfo enc_opts[] = {
{"bc", "bitrate container", "rc_container, 0:off 1:weak 2:strong", mpi_enc_opt_bc}, {"bc", "bitrate container", "rc_container, 0:off 1:weak 2:strong", mpi_enc_opt_bc},
{"ibias", "bias i", "bias_i", mpi_enc_opt_bias_i}, {"ibias", "bias i", "bias_i", mpi_enc_opt_bias_i},
{"pbias", "bias p", "bias_p", mpi_enc_opt_bias_p}, {"pbias", "bias p", "bias_p", mpi_enc_opt_bias_p},
{"speed", "enc speed", "speed", mpi_enc_opt_speed}, {"lmd", "lambda idx", "lambda_idx_p 0~8", mpi_enc_opt_lmd},
{"lmdi", "lambda i idx", "lambda_idx_i 0~8", mpi_enc_opt_lmdi},
{"speed", "enc speed", "speed mode", mpi_enc_opt_speed},
{"kmpp", "kmpp path enable", "kmpp path enable", mpi_enc_opt_kmpp} {"kmpp", "kmpp path enable", "kmpp path enable", mpi_enc_opt_kmpp}
}; };

View File

@@ -83,11 +83,14 @@ typedef struct MpiEncTestArgs_t {
/* -qpdd cu_qp_delta_depth */ /* -qpdd cu_qp_delta_depth */
RK_S32 cu_qp_delta_depth; RK_S32 cu_qp_delta_depth;
RK_S32 anti_flicker_str; RK_S32 anti_flicker_str;
RK_S32 atf_str;
RK_S32 atr_str_i; RK_S32 atr_str_i;
RK_S32 atr_str_p; RK_S32 atr_str_p;
RK_S32 atl_str; RK_S32 atl_str;
RK_S32 sao_str_i; RK_S32 sao_str_i;
RK_S32 sao_str_p; RK_S32 sao_str_p;
RK_S32 lambda_idx_p;
RK_S32 lambda_idx_i;
RK_S32 speed; RK_S32 speed;
/* -dbe deblur enable flag /* -dbe deblur enable flag
* -dbs deblur strength * -dbs deblur strength