Stage機(jī)器人仿真實(shí)驗(yàn)(Ubuntu16.04+Kinetic)

參考http://www.reibang.com/p/682e80efbe5a
首先創(chuàng)建工作空間,創(chuàng)建工作空間

mkdir -p ~/test_ws/src
cd  ~/test_ws
catkin_make 
source devel/setup.bash

在~t/test_ws/src下創(chuàng)建功能包,創(chuàng)建功能包

catkin_create_pkg beginner_tutorials std_msgs roscpp rospy

在~/test_ws/src/beginner_tutorials中拷貝從/opt/ros/kinetic/share/turtlebot_stage中復(fù)制的maps文件夾
在~/test_ws/src/beginner_tutorials/src中創(chuàng)建sharemem.h文件驹止,其中定義共享空間中的數(shù)據(jù)結(jié)構(gòu)淋样。文件內(nèi)容為

#ifndef SHAREMEM_H
#define SHAREMEM_H
struct ShareMem
{
  double x; //  x方向的速度(前后)
  double y; //  y方向的速度(左右)
  double z; //  旋轉(zhuǎn)
};
#endif

新建talker節(jié)點(diǎn)。創(chuàng)建共享內(nèi)存禀综、監(jiān)聽共享內(nèi)存區(qū)域的速度變化和發(fā)布速度話題截驮。

/****************************************
*文件名: talker.cpp            *
*簡(jiǎn)介: 鏈接非ROS進(jìn)程和ROS節(jié)點(diǎn)的ROS節(jié)點(diǎn)   *
*BY: CR (qq: 414481619)         *
*創(chuàng)建時(shí)間: 2018.10.09           *
****************************************/

#include "ros/ros.h"
#include <geometry_msgs/Twist.h>

#include <iostream>
#include <stdio.h>
#include <sys/shm.h>
#include <errno.h>
#include <sys/types.h>
#include <stdlib.h>
#include <pthread.h>

#include "sharemem.h"

using namespace std;


int main(int argc, char **argv)
{

  ros::init(argc, argv, "talker");
  ros::NodeHandle n;
  ros::Publisher chatter_pub = n.advertise<geometry_msgs::Twist>("cmd_vel", 1000);

  ros::Rate loop_rate(100); // 100Hz的定時(shí)器

  
  ShareMem _ShareMem;
  // 創(chuàng)建共享內(nèi)存 捌浩,相當(dāng)于打開文件,文件不存在則創(chuàng)建
  int shmid = shmget((key_t)2333, sizeof(_ShareMem), 0666|IPC_CREAT);  
  if(shmid==-1)
  {
    perror("shmget err");
    return errno;
  }
  cout<<shmid<<endl; 

  // 將共享內(nèi)存段連接到進(jìn)程地址空間, 第二個(gè)參數(shù)shmaddr為NULL笛臣,核心自動(dòng)選擇一個(gè)地址
  ShareMem *shareMem = (ShareMem *)shmat(shmid, NULL, 0); 
  if (shareMem == (void *)-1 )
  {
    perror("shmat err");
    return errno;
  }
  
  shareMem->x = 0;  
  shareMem->y = 0; 
  shareMem->z = 0; 

  pthread_mutex_t mutex;  
  pthread_mutex_init(&mutex, NULL);
  while (ros::ok())
  {
    geometry_msgs::Twist cmdvel_msg; 

    pthread_mutex_lock(&mutex);
    cmdvel_msg.linear.x = shareMem->x;  
    cmdvel_msg.linear.y = shareMem->y; 
    cmdvel_msg.angular.z = shareMem->z; 
    pthread_mutex_unlock(&mutex);
    chatter_pub.publish(cmdvel_msg);

    ros::spinOnce();

    loop_rate.sleep();
  }
  pthread_mutex_destroy(&mutex);
  shmdt(shareMem);  //將共享內(nèi)存段與當(dāng)前進(jìn)程脫離
  shmctl(shmid, IPC_RMID, NULL); //IPC_RMID為刪除內(nèi)存段
  return 0;
}

在beginner_tutorials 的 CMakeLists.txt 中添加:

include_directories(include ${catkin_INCLUDE_DIRS})

add_executable(talker src/talker.cpp)
target_link_libraries(talker ${catkin_LIBRARIES})

在終端中:

cd ~/test_ws
catkin_make

創(chuàng)建launch文件新建launch文件夾云稚,創(chuàng)建stage_tast.launch文件。

<!--   
  stage_test 
  - stage_ros
  - talker
 -->
<launch>  
  <arg name="world_file"     default=" $(find beginner_tutorials)/maps/stage/maze.world"/>  

  <node pkg="stage_ros" type="stageros" name="stageros" args="$(arg world_file)">  
    <param name="base_watchdog_timeout" value="0.5"/>  
    <remap from="odom" to="odom"/>  
    <remap from="base_pose_ground_truth" to="base_pose_ground_truth"/>  
    <remap from="cmd_vel" to="cmd_vel"/>  
  </node>  

  <node pkg="beginner_tutorials" type="talker" name="talker">
  </node>  

</launch>  

創(chuàng)建速度控制父類沈堡,便于其他速度控制類的編寫静陈,其他速度控制類只需要繼承父類的框架,完成自己的mainloop()就好诞丽。

/****************************************
*文件名: VelControl.h          *
*簡(jiǎn)介: 速度控制父類         *
*BY: CR (qq: 414481619)         *
*創(chuàng)建時(shí)間: 2018.10.09           *
****************************************/

// this code ism't in ros system 

#include <iostream>
#include <stdio.h>
#include <sys/shm.h>
#include <errno.h>
#include <sys/types.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>

#include "sharemem.h"

using namespace std;

class VelControl
{
public:
    VelControl();
    ~VelControl();
    void mainloop();
protected:
    ShareMem *shareMem;
    pthread_mutex_t mutex;  
    void writeVel(double x, double y, double z);
};

VelControl::VelControl()
{
    pthread_mutex_init(&mutex, NULL);

    // 綁定共享內(nèi)存
    int shmid = shmget((key_t)2333, 0, 0);  
    if(shmid != -1)
    {
        shareMem =(ShareMem *)shmat(shmid, NULL, 0);
        cout<<shmid<<endl;
    }
    else
    {
        cout<<"ERROR: stage_test haven't started"<<endl;
        exit(1);
    }
}

VelControl::~VelControl()
{
    shmdt(shareMem);  //將共享內(nèi)存段與當(dāng)前進(jìn)程脫離
    pthread_mutex_destroy(&mutex);
}


void VelControl::writeVel(double x, double y, double z)
{
    pthread_mutex_lock(&mutex);
    shareMem->x = x;  
    shareMem->y = y; 
    shareMem->z = z;
    pthread_mutex_unlock(&mutex);
}

鍵盤控制例程

/****************************************
*文件名: keyboard_not_ros.cpp      *
*簡(jiǎn)介: 速度控制例程         *
*BY: CR (qq: 414481619)         *
*創(chuàng)建時(shí)間: 2018.10.09           *
****************************************/

// this code isn't in ros system 

#include "VelControl.h"

using namespace std;

class keyboard_not_ros:VelControl
{
public:
    void mainloop();
};

void keyboard_not_ros::mainloop()
{
    char c = 'a';
    while(c!='q')
    {
        cout<<"please input a letter"<<endl;
        c = getchar();
        getchar();
        double x,y,z;
        switch(c)
        {
            
            case 'W':
            case 'w':
                x = 1;
                y = 0;
                z = 0;
                break;
            case 'S':
            case 's':
                x = -1;
                y = 0;
                z = 0;
                break;
            case 'A':
            case 'a':
                x = 0;
                y = 0;
                z = 1;
                break;
            case 'D':
            case 'd':
                x = 0;
                y = 0;
                z = -1;
                break;
            default:;
        }
        writeVel(x, y, z);
        usleep(100*1000);
        writeVel(0,0,0);
    }
}


int main(int argc, char const *argv[])
{
    keyboard_not_ros k;
    k.mainloop();
    return 0;
}

編譯程序鲸拥,在 ~/test_ws/src/beginner_tutorials/src/ 目錄下,終端輸入:
g++ -o keyboard_not_ros keyboard_not_ros.cpp
啟動(dòng)launch文件

roslaunch beginner_tutorials stage_test.launch 

另一個(gè)終端中僧免,~/test_ws/src/beginner_tutorials/src下輸入

./keyboard_not_ros
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刑赶,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子懂衩,更是在濱河造成了極大的恐慌撞叨,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浊洞,死亡現(xiàn)場(chǎng)離奇詭異牵敷,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)法希,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門枷餐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人苫亦,你說我怎么就攤上這事尖淘。” “怎么了著觉?”我有些...
    開封第一講書人閱讀 168,386評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)惊暴。 經(jīng)常有香客問我饼丘,道長(zhǎng),這世上最難降的妖魔是什么辽话? 我笑而不...
    開封第一講書人閱讀 59,726評(píng)論 1 297
  • 正文 為了忘掉前任肄鸽,我火速辦了婚禮卫病,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘典徘。我一直安慰自己蟀苛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評(píng)論 6 397
  • 文/花漫 我一把揭開白布逮诲。 她就那樣靜靜地躺著帜平,像睡著了一般。 火紅的嫁衣襯著肌膚如雪梅鹦。 梳的紋絲不亂的頭發(fā)上裆甩,一...
    開封第一講書人閱讀 52,337評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音齐唆,去河邊找鬼嗤栓。 笑死,一個(gè)胖子當(dāng)著我的面吹牛箍邮,可吹牛的內(nèi)容都是我干的茉帅。 我是一名探鬼主播,決...
    沈念sama閱讀 40,902評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼锭弊,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼堪澎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起廷蓉,我...
    開封第一講書人閱讀 39,807評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤全封,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后桃犬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刹悴,經(jīng)...
    沈念sama閱讀 46,349評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評(píng)論 3 340
  • 正文 我和宋清朗相戀三年攒暇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了土匀。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,567評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡形用,死狀恐怖就轧,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情田度,我是刑警寧澤妒御,帶...
    沈念sama閱讀 36,242評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站镇饺,受9級(jí)特大地震影響乎莉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評(píng)論 3 334
  • 文/蒙蒙 一惋啃、第九天 我趴在偏房一處隱蔽的房頂上張望哼鬓。 院中可真熱鬧,春花似錦边灭、人聲如沸异希。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽称簿。三九已至,卻和暖如春椭坚,著一層夾襖步出監(jiān)牢的瞬間予跌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工善茎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留券册,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,995評(píng)論 3 377
  • 正文 我出身青樓垂涯,卻偏偏與公主長(zhǎng)得像烁焙,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子耕赘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容