本文做者:Apollo开发者社区javascript
预测模块是不可或缺的一个板块,其做用很大程度上决定了试验可否成功。预测模块综合各个模块的数据信息和评价结果,具有信息融合功能,能够评估各个子系统及系统总体将来的状态,开发者可根据预测模块的评估结果进行调整。而加入新的Evaluator,更是能自定义评估方向,增长评估结果准确度。java
如下,ENJOY app
评估器使用预训练的深度学习模型生成特征(来自障碍物和自车的原始信息)以得到模型输出。ide
请参照如下步骤新增一个名为NewEvaluator的评估器:函数
在proto中新增一个文件学习
以继承Evaluator类的方式定义一个新类NewEvaluatorlua
实现NewEvaluator类spa
更新预测配置文件code
更新评估管理器继承
在modules/prediction/evaluator/vehicle文件夹下建立文件new_evaluator.h
文件内容以下:
#include "modules/prediction/evaluator/evaluator.h" namespace apollo { namespace prediction { class NewEvaluator : public Evaluator { public: NewEvaluator(); virtual ~NewEvaluator(); void Evaluate(Obstacle* obstacle_ptr) override; // Other useful functions and fields. }; } // namespace prediction } // namespace apollo
在相同文件夹下建立一个名为new_evaluator.cc的文件,实现新定义的类。新类的实现方法以下所示:
#include "modules/prediction/evaluator/vehicle/new_evaluator.h" namespace apollo { namespace prediction { NewEvaluator::NewEvaluator() { // Implement } NewEvaluator::~NewEvaluator() { // Implement } NewEvaluator::Evaluate(Obstacle* obstacle_ptr)() { // Extract features // Compute new_output by applying pre-trained model } // Other functions } // namespace prediction } // namespace apollo
在文件prediction_conf.proto中增长一个类型来表示新增的评估器,以下所示:
enum EvaluatorType { MLP_EVALUATOR = 0; NEW_EVALUATOR = 1; }
在配置文件modules/prediction/conf/prediction_conf.pb.txt中,更新evaluator_typ域,具体以下所示:
obstacle_conf { obstacle_type: VEHICLE obstacle_status: ON_LANE evaluator_type: NEW_EVALUATOR predictor_type: NEW_PREDICTOR }
按照下面的代码示例更新函数CreateEvluator( ... ):
case ObstacleConf::NEW_EVALUATOR: { evaluator_ptr.reset(new NewEvaluator()); break; }
按照下面的代码示例更新函数RegisterEvaluators():
RegisterEvaluator(ObstacleConf::NEW_EVALUATOR);
完成上述步骤以后,即表示建立了新的评估器。
若是您想增长新的属性,请参照如下说明:
假设新的评估输出结果为new_output而且其类型为int32。
若是输出直接与障碍物相关,请参考如下代码在modules/prediction/proto/feature.proto文件中增长新的域:
message Feature { // Other existing features optional int32 new_output = 1000; }
若是输出与车道序列相关,请参考如下代码在modules/prediction/proto/lane_graph.proto文件中增长新的域:
message LaneSequence { // Other existing features optional int32 new_output = 1000; }