评估¶
eval_config¶
eval_config {
metrics_set: {
# metric为auc
auc {}
}
}
当转化率很低(万分之3左右)的时候,可以在auc中再设置一个参数num_thresholds:
auc {
num_thresholds: 10000
}
metrics_set: 配置评估指标,可以配置多个,如:
eval_config {
metrics_set: {
auc {}
}
metrics_set: {
accuracy {}
}
metrics_set: {
gauc {}
}
}
num_examples: 默认为0, 表示评估所有样本;大于0,则每次只评估num_examples样本,一般在调试或者示例的时候使用
备注 在多目标模型里, eval_config 的 metrics_set 无效,请使用 model 里面的 metrics_set 配置 参见文档 [MODEL]->[多目标模型] 配置中的 model_config.[model].task_towers.metrics_set
Metric:¶
MetricClass | Example | 适用模型 |
---|---|---|
Accuracy | accuracy {} | 多分类模型LossType=CLASSIFICATION, num_class > 1 |
MeanAbsoluteError | mean_absolute_error {} | 回归模型LossType=L2_LOSS |
RecallAtTopK | recall_at_topk {} | 多分类模型LossType=CLASSIFICATION, num_class > 1; CoMetricLearningI2I模型 |
Max_F1 | max_f1 {} | 分类模型LossType=CLASSIFICATION |
MeanSquaredError | mean_squared_error{} | 回归模型LossType=L2_LOSS |
AUC | auc{} | 二分类模型LossType=CLASSIFICATION, num_class = 1 |
GAUC | gauc{} | 二分类模型LossType=CLASSIFICATION, num_class = 1 |
SessionAUC | session_auc{} | 二分类模型LossType=CLASSIFICATION, num_class = 1 |
Precision | precision{} | 二分类模型LossType=CLASSIFICATION, num_class = 1 |
Recall | recall{} | 二分类模型LossType=CLASSIFICATION, num_class = 1 |
AvgPrecisionAtTopK | precision_at_topk{topk=5} | CoMetricLearningI2I模型专用, LossType=CIRCLE_LOSS / MULTI_SIMILARITY_LOSS |
备注 GAUC 在使用时,uid 字段需要在 feature_config 里配置,否则 uid 字段会被丢弃 示例
eval_config {
metrics_set: {
gauc {
uid_field: 'user_id'
}
}
}
...
feature_config: {
features: {
input_names:"user_id"
feature_type:IdFeature
embedding_dim:16
hash_bucket_size:5000
}
...
}
评估命令¶
Local¶
python -m easy_rec.python.eval --pipeline_config_path dwd_avazu_ctr_deepmodel.config
–pipeline_config_path: config文件路径
–model_dir: 如果指定了model_dir将会覆盖config里面的model_dir,一般在周期性调度的时候使用
PAI¶
pai -name easy_rec_ext -project algo_public
-Dcmd=evaluate
-Dconfig=oss://easyrec/config/MultiTower/dwd_avazu_ctr_deepmodel_ext.config
-Deval_tables=odps://pai_online_project/tables/dwd_avazu_ctr_deepmodel_test
-Dcluster='{"worker" : {"count":1, "cpu":1000, "gpu":100, "memory":40000}}'
-Dmodel_dir=oss://easyrec/ckpt/MultiTower
-Darn=acs:ram::xxx:role/xxx
-Dbuckets=oss://easyrec/
-DossHost=oss-cn-beijing-internal.aliyuncs.com;
-Dcmd: evaluate 模型评估
-Dconfig: 同训练
-Deval_tables: 指定测试 tables
-Dcluster: 评估不需要PS节点,指定一个worker节点即可
-Dmodel_dir: 如果指定了model_dir将会覆盖config里面的model_dir,一般在周期性调度的时候使用
-Dcheckpoint_path: 使用指定的checkpoint_path,如oss://easyrec/ckpt/MultiTower/model.ckpt-1000。不指定的话,默认model_dir中最新的ckpt文件。
如果是pai内部版,则不需要指定arn和ossHost, arn和ossHost放在-Dbuckets里面
-Dbuckets=oss://easyrec/?role_arn=acs:ram::xxx:role/ev-ext-test-oss&host=oss-cn-beijing-internal.aliyuncs.com
-Deval_result_path: 保存评估结果的文件名, 默认是eval_result.txt, 保存目录是model_dir.
分布式评估¶
pai -name easy_rec_ext -project algo_public
-Dcmd=evaluate
-Dconfig=oss://easyrec/config/MultiTower/dwd_avazu_ctr_deepmodel_ext.config
-Deval_tables=odps://pai_online_project/tables/dwd_avazu_ctr_deepmodel_test
-Dcluster='{"ps":{"count":1, "cpu":1000}, "worker" : {"count":3, "cpu":1000, "gpu":100, "memory":40000}}'
-Dmodel_dir=oss://easyrec/ckpt/MultiTower
-Dextra_params=" --distribute_eval True"
-Darn=acs:ram::xxx:role/xxx
-Dbuckets=oss://easyrec/
-DossHost=oss-cn-beijing-internal.aliyuncs.com;
-distribute_eval: 分布式 evaluate
评估结果: 会写到model_dir目录下的-Deval_result_path指定的文件名(默认是eval_result.txt)里面。