我是靠谱客的博主 无语书包,最近开发中收集的这篇文章主要介绍apollo代码学习2.3——深度解析(control),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

每次遇见复杂的事情总是在先寻找一种简单明了的方式进行研究,用一种浅显易懂的方式来表达。

 

 

 今天继续apollo代码中control模块的总结。

还是老样子为了与前面文章衔接,先看下总框架图吧:

 对于control模块,前面的已将其流程大致梳理,依旧先看下spin函数。

 

 

int ApolloApp::Spin() {
ros::AsyncSpinner spinner(callback_thread_num_);
///开消息线程
auto status = Init();
///模块初始化(由子类具体重写的)
if (!status.ok()) {
AERROR << Name() << " Init failed: " << status;
return -1;
}
status = Start();
///模块开启(由子类具体重写的)
if (!status.ok()) {
AERROR << Name() << " Start failed: " << status;
return -2;
}
ExportFlags();
///输出一些flag参数
spinner.start();
///消息线程开启
ros::waitForShutdown();
///消息循环处理并检测关闭
Stop();
///退出(由子类具体重写的)
AINFO << Name() << " exited.";
///将退出信息记录到日志文件中
return 0;
}

 

 包括:开消息线程---->初始化模块---->开启---->输出flag参数---->消息处理开启---->循环处理并检测关闭---->关闭。其实对于其中最为复杂重要的步骤已经梳理完毕(初始化和开启),接着的输出flags参数就是类似文件流的功能,把control所设置好的参数放在一个control.flags文件中,熟悉apollo代码的人方便后续查看,排错。代码贴在下面。

 

/**
* @brief:将模块的flags设置进行输出。
* --log_dir=/apollo/data/log。
* 对于control模块,具体可以直接去运行出来的目录中查看,/apollo/data/log/control.flags文件中查看。
*/
void ApolloApp::ExportFlags() const {
const auto export_file = util::StrCat(FLAGS_log_dir, "/", Name(), ".flags");
std::ofstream fout(export_file);
CHECK(fout) << "Cannot open file " << export_file;
std::vector<gflags::CommandLineFlagInfo> flags;
gflags::GetAllFlags(&flags);
for (const auto &flag : flags) {
fout << "# " << flag.type << ", default=" << flag.default_value << "n"
<< "# " << flag.description << "n"
<< "--" << flag.name << "=" << flag.current_value << "n"
<< std::endl;
}
}

 

 后面的代码就是ros下的处理了,apollo使用ros::AsyncSpinner这个类来开线程,对于spinner.start就是其中的函数,最后的stop函数具体应该由模块子类中进行实现(有些模块为空)。

这样,control模块的大致流程就算是梳理好了,但是倘若想深入理解ros机制在apollo中的封装,模块里面具体

算法的实现与调用方式,仅仅靠这几篇博文就显得远远不够详细,其实际上还没有涉及到这些内容的梳理,那么后面我还将继续在这两方面进行总结,加深对apollo代码的理解。

最后

以上就是无语书包为你收集整理的apollo代码学习2.3——深度解析(control)的全部内容,希望文章能够帮你解决apollo代码学习2.3——深度解析(control)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(59)

评论列表共有 0 条评论

立即
投稿
返回
顶部