SLAM拾萃(2):doxygen
今天给大家介绍一下doxygen。这个工具由来已久了,至少08年左右就已经在用了,但是目前还没见到好的介绍。我个人觉得这是个很简单易用的工具,但是为什么看了别人介绍反而觉得复杂了……所以趁着今天比较闲就来说一说它。
doxygen是一个自动文档生成工具,根据代码里写的注释,自动生成html和latex格式的文档。通常是给c++用的,通常是出html格式的,你看到的pcl网上文档就是拿doxygen生成的。
事实上,随意一份代码,都可以拿doxygen生成一个文档,然后在本地看它的代码结构。 我们拿以难读著称的lsd-slam举个例子。
首先,建个文件夹,把lsd-slam的代码拷下来:
git clone https://github.com/tum-vision/lsd_slam.git
拷完之后lsd就在你电脑里躺着了。进到package_dir/lsd_slam/lsd_slam_core,打开一看?哇,一堆文件。仔细一看?哇,好多类和变量,还有藏着掖着的全局变量,还有SSE指令!太多了,没法看,怎么办?别急,我们用doxygen生成一个网页来看。网页的好处是可以随处跳转。
由于你电脑里可能还没有doxygen,我们先来安装一下:
sudo apt-get install doxygen doxygen-gui
什么?你不是Ubuntu怎么办?你都不用Ubuntu了还用我教你装软件?
昂,总之,主要是doxygen本体和它的gui模块。我在ubuntu14.04下是这两个包名。如果你不确定,请用apt-cache search doxygen查一下。
装好了之后,在该文件夹下开一个doc文件夹,把一会儿生成的文档放里头:
mkdir doc; cd doc
然后,输入doxywizard调出gui面板。
doxywizard
然后就会出一个面板啦,来看看上面都有啥:(外观视你的桌面环境可能略有不同)
大概能看出哪些地方要设置吧?首先把Step 1中的目录设到你要保存文档的目录。Project name那些东西随意,可以不设。比较重要的是源代码目录source code directory,请把它设到lsd_slam_core/src下,并钩上Scan recursively,表明我们要扫描子文件夹。然后,输出文件夹设成当前目录./即可,本来我们就在当前目录嘛。
这步做好了,点左边的“Mode”,进入下一个版块。下个版块里会让你选语言,既然咱们用c++,保持默认的就可以了。
Output和Diagrams也没什么好动的。
现在准备工作完成啦!切到Run,点“Run doxygen",哗啦哗啦,等文档生成完。然后点“show html output",就可以在浏览器里看到文档啦。如果你下一次想直接看,直接打开doc/html/index.html就可以了!
是不是和网上的文档很像啊?看这个比看源代码效果更高哦!
命令行
doxygen本身是命令行格式的,给一个配置文件,然后根据配置文件去生成文档。但是!几百个配置选项我怎么记得住啊!既然图形界面那么好用为啥要去用命令行啊!哦你没有桌面环境?那还是乖乖用命令行吧……
命令行的doxygen也很简单。首先用
doxygen -s -g settings.txt
生成一个配置文件,然后去修改配置文件里的值,基本上和上面讲的差不多啦!只是配置会复杂一点。比较重要的参数有输入,输出,扫描文件的后缀名等等。其实这些都可以在图形界面的“Expert“里配的!我也是这么干的!所以如果你有屏幕的话还是建议你用图形界面啦!当这个文件改好后,调用
doxygen settings.txt
按这个文件生成文档。当然如果你写错了,文档就不会生成了!所以还是用图形界面吧!(我在俊哥面前就调了半天这东西的配置文件结果人家妹子都睡着了我才调出来,所以在妹子面前调程序请务必找个熟悉的调)
后话
doxygen还能按照一些特殊注释格式来生成特别的文档。如果你感兴趣,可以看看上一讲octomap里的那个doc/目录。它也可以用doxygen生成一个文档,但那个文档功能更高级些,可以显示类继承关系树状图等等。据说还能生成别的语言的注释,然而像python估计也不需要这种工具……总之,你要玩的话,doxygen还是有些东西可以玩的,虽然并不太多。本着KISS原则,我还是把它当成一个简单好用的小工具,不必太折腾就能出文档啦!那么,本讲就写到这里,咱们下次再见!
SLAM拾萃(2):doxygen的更多相关文章
- SLAM拾萃(1):octomap
前言 大家好,时隔多年之后,我又开始了博客旅程.经历了很多事情之后呢,我发现自己的想法真的很简单:好好读书做课题,闲下来时写写博客,服务大家.所以我会继续写SLAM相关的博客.如果你觉得它对你有帮助, ...
- SLAM拾萃(3):siftGPU
前言 本周博客我们给大家介绍一下SiftGPU.由于特征匹配是SLAM中非常耗时间的一步,许多人都想把它的时间降至最短,因此目前ORB成了非常受欢迎的特征.而老牌SIFT,则一直给人一种“很严谨很精确 ...
- octomap的简介
装载自高翔博士的博客:https://www.cnblogs.com/gaoxiang12/p/5041142.html 什么是octomap? RGBD SLAM的目的有两个:估计机器人的轨迹,并建 ...
- [学习笔记]SiftGPU入门
当有读者看到我这篇SiftGPU入门的学习笔记时,相信你已经读过了高博那篇<SLAM拾萃:SiftGPU>,那篇文章写于16年,已经过去两年的时间.在我尝试配置SiftGPU的环境时,遇到 ...
- 在QtCreator中使用doxygen
接触Doxygen后,认识到其强大之处,一口气将之前的烂代码重构了一遍,所有的文件头,函数注释等等都是手动添加注释.在keil中可以看到其对JavaDoc风格的注释有高亮,非常好看.但是keil这个I ...
- Windows下使用doxygen阅读和分析C/C++代码
Windows下使用doxygen阅读和分析C/C++代码 转自:http://blog.sina.com.cn/s/blog_63d902570100gwk6.html 虽然使用各种IDE或者Sou ...
- (转)Doxygen文档生成工具
http://blog.csdn.net/lostaway/article/details/6446786 Doxygen 是一个支持 C/C++,以及其它多种语言的跨平台文档生成工具.如同 Java ...
- Slam(即时定位与地图构建) 知识篇
Slam即时定位与地图构建 技术解释 同步定位与地图构建(SLAM或Simultaneous localization and mapping)是一种概念:希望机器人从未知环境的未知地点出发,在运动过 ...
- ubuntu使用doxygen
1.安装 sudo apt-get install doxygen按tab键 doxygen doxygen-dbg doxygen-doc doxygen-gui d ...
随机推荐
- yum安装apache及问题解决
一.检查服务器上是否已经安装了apache apache在linux系统里的名字是httpd,执行以下命令,如果有返回的信息,则会显示已经安装的软件.如果没有则不会显示其它的信息. rpm -qa h ...
- LCD RGB 控制技术 时钟篇(下)
我们先回顾一下之前的典型时序图 在这个典型的时序图里面,除了上篇博文讲述的HSYNC VSYNC VDEN VCLK这几信号外,我们还能看见诸如HSPW. VSPW,HBPD. HFPD,VBPD. ...
- linux Posix 信号量 三 (经典例子)
本文将阐述一下信号量的作用及经典例子,当中包括“<越狱>寄信”,“家庭吃水果”,“五子棋”,“接力赛跑”,“读者写者”,“四方恋爱”等 首先,讲 semWait操作(P操作)和semSig ...
- <只看这个就够了。。。>Android自动化测试及性能优化
Android自动化测试及性能优化 分类: Android Java Tools2012-12-09 23:31 4300人阅读 评论(0) 收藏 举报 软件自动化测试对于程序员来说能够确保软件开发的 ...
- 修改Gradle 和Maven本地仓库的位置方法
本文转载自:https://www.cnblogs.com/dwb91/p/6523541.html 关于Maven的配置: 用过Maven的开发人员应该知道Maven可以通过配置 conf文件夹下面 ...
- 汇编_指令_FLAGS
标志名 标志 1 标志 0 OF (溢出标志) OV ...
- Java-Runoob-高级教程-实例-字符串:05. Java 实例 - 字符串反转
ylbtech-Java-Runoob-高级教程-实例-字符串:05. Java 实例 - 字符串反转 1.返回顶部 1. Java 实例 - 字符串反转 Java 实例 以下实例演示了如何使用 J ...
- SCN与数据恢复的关系
Oracle内部主要存在以下四种SCN 1.系统检查点(system checkpoint)SCN 每当一个检查点完成时,Oracle就把该检查点对应的SCN记录到控制文件中,可以用以下语句查看当前数 ...
- 蚂蚁社招Java-第四轮电话面试【技术终面】
作者:听着歌过面试链接:https://www.nowcoder.com/discuss/64708来源:牛客网 蚂蚁社招Java-第四轮电话面试[技术终面] 转载 (耗时22分钟,其实聊得东西挺 ...
- OpenMP n 体问题
▶ <并行程序设计导论>第六章中讨论了 n 体问题,分别使用了 MPI,Pthreads,OpenMP 来进行实现,这里是 OpenMP 的代码,分为基本算法和简化算法(引力计算量为基本算 ...