zoukankan      html  css  js  c++  java
  • REMODE+ORBSLAM运行配置(2) REMODE和编译后的ORB ros工程利用节点实现通讯

    将ORB编译成ROS工程后,就可以利用ROS的节点通信实现ORB和REMODE的数据传输。

    步骤:

    1 仿照SVO-REMODE的编译方式。安装googletest 和rpg_open_remode至~/catkin_ws/src 目录下。

    2 修改 ORB的主函数,以便发送数据。

    2.1 加入头文件

    #include<vikit/file_reader.h>      
    #include<vikit/params_helper.h> 
    #include<vikit/camera_loader.h>
    //以上几个头文件是从程序外从参数用的,需要下载vikit源码
    #include<cv_bridge/cv_bridge.h>
    #include <sensor_msgs/image_encodings.h>
    #include <image_transport/image_transport.h>
    //以上3个头文件是发送图片用的
    #include<ros/ros.h>
    #include<ros/package.h>
    #include"std_msgs/String.h"
    #include"sstream"
    #include"DenseInput.h"//这个头文件 说明了传输数据的结构,需要从svo工程svo_msgs里的拷出来。
    #include <Converter.h>//位姿矩阵转四元素
    #include <pangolin/pangolin.h>
    #include <iomanip>

    2.2 在main函数中完成通信

    以下修改在main函数中

    开启ros节点,vk::getParam才能找到launch文件的参数

    ros::init(argc,argv,"ORB_SLAM");
       ros::NodeHandle SendMessage;
    // 发布
       ros::Publisher pub_dense_=SendMessage.advertise<svo_msgs::DenseInput>("dense_input",10);
       //利用vikit读取参数
        const string dataset_path(vk::getParam<std::string>("ORB_SLAM/Img_Path"));
        const string CamPara_Path(vk::getParam<std::string>("ORB_SLAM/CamPara_Path"));
        const string BOW_Path(vk::getParam<std::string>("ORB_SLAM/BOW_Path"));
     

    发送数据:每执行一次slam,发送一次数据。数据包括 

    1 frame的id

    2 左图

    3 四元数格式的位姿

    4 当前场景的最大最小深度。

    /////////////////////////////////////////////////////////与REMODE通信//////////////////////////////
    
    	svo_msgs::DenseInput msg;
    	msg.header.stamp=ros::Time(20);//svo中设置20可以正常运行
    	msg.header.frame_id="/world";
    	msg.frame_id=framecnt;
    	cv_bridge::CvImage img_msg;
    	img_msg.header.stamp=msg.header.stamp;
    	img_msg.header.frame_id="camera";
    	img_msg.image=imRGB;
    
    	img_msg.encoding = sensor_msgs::image_encodings::MONO8;
    	msg.image = *img_msg.toImageMsg();
    
    	double min_z = std::numeric_limits<double>::max();
    	double max_z = std::numeric_limits<double>::min();
    	SLAM.mpTracker->getSceneDepth(SLAM.mpTracker->mCurrentFrame,max_z,min_z);
    	cout<<"min_z-----------------------------------------  "<<min_z<<endl;
    	cout<<"max_z-------------------------------------------  "<<max_z<<endl;
             msg.min_depth=(float)min_z;
             msg.max_depth=(float)max_z;
    
    	cv::Mat  TWC=SLAM.mpTracker->mCurrentFrame.mTcw.inv();
    	cv::Mat RWC=TWC.rowRange(0,3).colRange(0,3);
    	cv::Mat tWC=TWC.rowRange(0,3).col(3);
    	vector<float> q=ORB_SLAM2::Converter::toQuaternion(RWC);
    
    
    
    	    msg.pose.position.x = tWC.at<float>(0,0);
    	    msg.pose.position.y = tWC.at<float>(1,0);
    	    msg.pose.position.z = tWC.at<float>(2,0);
    	    msg.pose.orientation.w = q[3];//q.w();
    	    msg.pose.orientation.x = q[0];//q.x();
    	    msg.pose.orientation.y = q[1];//q.y();
    	    msg.pose.orientation.z = q[2];//q.z();
    	    pub_dense_.publish(msg);
    ////////////////////////////////////////////////////////////////////////////////////////////////////////
    

    opencv的cv::Mat  和ros中的sensor_msgs/Image 需要cv_bridge::CvImage  做个转换。

    用法:http://wiki.ros.org/cv_bridge/Tutorials/UsingCvBridgeToConvertBetweenROSImagesAndOpenCVImages

    3 仿照

    ubuntu下通过命令打开多个终端并在相应终端执指令

    写一个脚本,目的是在运行工程的时候方便,快捷。脚本内容为

    gnome-terminal -x bash -c "roscore"
    gnome-terminal -x bash -c "rosrun rviz rviz -d /home/baohua/project/SLAM/REMODE_ORB/catkin_ws/src/rpg_open_remode/open_remode.rviz  "
    gnome-terminal -x bash -c " source '/home/baohua/project/SLAM/REMODE_ORB/catkin_ws/devel/setup.sh';roslaunch ORB_SLAM MH01.launch "
    gnome-terminal -x bash -c " source '/home/baohua/project/SLAM/REMODE_ORB/catkin_ws/devel/setup.sh';roslaunch rpg_open_remode remode_EuRoC.launch "


    至此,运行脚本就可以运行REMODE+ORBSLAM工程了。

     
  • 相关阅读:
    feq ifneq ifdef ifndef
    clock gating | ODC-based Clock Gating
    clock gating | clock gating的timing check
    更换ICC2图形界面主题
    git 学习心得
    CSS颜色混合模式
    常用meta整理
    75份开发者、设计师必备的速查表
    jquery 编程的最佳实践
    JQuery总结一:选择器归纳
  • 原文地址:https://www.cnblogs.com/zhubaohua-bupt/p/7182804.html
Copyright © 2011-2022 走看看