run_simulation.sh 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. #!/bin/bash
  2. # 检查到未定义的变量则停止执行并报错
  3. set -u
  4. # 检查参数数量
  5. if [ "$#" -ne 5 ]; then
  6. echo "Error: Incorrect number of arguments"
  7. echo "Usage: $0 OBSTACLE_FLAG DEFAULT_START_FLAG DEFAULT_END_FLAG START_POINT END_POINT"
  8. exit 1
  9. fi
  10. OBSTACLE_FLAG=$1
  11. DEFAULT_START_FLAG=$2
  12. DEFAULT_END_FLAG=$3
  13. START_POINT=$(echo "$4" | tr ',' ' ')
  14. END_POINT=$(echo "$5" | tr ',' ' ')
  15. BUILD_MAP_NAME="build_map.bag"
  16. MAP_BAG_NAME="origin_map.bag"
  17. SIMULATION_PATH="/home/cicv/work/pji_desktop/simulation"
  18. # 激活conda环境
  19. source activate simulation
  20. # 起点设置
  21. if [ "$DEFAULT_START_FLAG" == "true" ]; then
  22. # 默认起点
  23. echo "Use default start point"
  24. ## 配置默认起点
  25. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish custom $SIMULATION_PATH/data/map_bag/$MAP_BAG_NAME"
  26. ### 清除环境
  27. pkill -f "goal_publish/initialPose"
  28. pkill -f "goal_publish/custom"
  29. sleep 1
  30. echo 'bash -c '\""$command"\"
  31. nohup bash -c "$command" >/dev/null 2>&1 &
  32. sleep 1
  33. elif [ "$DEFAULT_START_FLAG" == "false" ]; then
  34. # 自定义起点
  35. echo "Setting start point: $START_POINT"
  36. ## 发布自定义起点 - gazebo
  37. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish initialPose $START_POINT"
  38. ### 清除环境
  39. pkill -f "goal_publish/initialPose"
  40. sleep 1
  41. echo 'bash -c '\""$command"\"
  42. nohup bash -c "$command" >/dev/null 2>&1 &
  43. sleep 1
  44. ## 发布自定义起点 - rviz
  45. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish initialPose_rviz $START_POINT"
  46. ### 清除环境
  47. pkill -f "goal_publish/initialPose_rviz"
  48. sleep 1
  49. echo 'bash -c '\""$command"\"
  50. nohup bash -c "$command" >/dev/null 2>&1 &
  51. ### 这里必须设置不少于5s的延迟时间,否则rviz中的起点设置会出现问题
  52. sleep 5
  53. echo "Start point: $START_POINT has been set"
  54. fi
  55. # 终点设置
  56. if [ "$DEFAULT_END_FLAG" == "true" ]; then
  57. # 默认终点
  58. echo "Use default end point"
  59. ## 发布默认终点
  60. # command="cd $SIMULATION_PATH/catkin_ws && source devel/setup.bash && rosrun goal_publish pub_node $SIMULATION_PATH/data/build_map_bag/$BUILD_MAP_NAME $SIMULATION_PATH/evaluation_bag/example_0821_4.bag"
  61. command="cd $SIMULATION_PATH/catkin_ws && rm -r build devel && catkin_make && source devel/setup.bash && rosrun goal_publish pub_node $SIMULATION_PATH/data/map_bag/$MAP_BAG_NAME $SIMULATION_PATH/data/old_bag/example.bag"
  62. ## 录包
  63. ### 激活conda环境
  64. # source activate simulation
  65. # nohup python "$SIMULATION_PATH"/rosbag_record.py "$SIMULATION_PATH"/data/record_bag/test.bag >/dev/null 2>&1 &
  66. ## 清除环境
  67. pkill -f "goal_publish/goal" # 下发自定义/默认终点前必须先清除goal,不能只清除pub_node
  68. pkill -f "goal_publish/pub_node"
  69. pkill -f "rosbag_record"
  70. sleep 1
  71. echo 'bash -c '\""$command"\"
  72. nohup python "$SIMULATION_PATH"/rosbag_record.py "$SIMULATION_PATH"/data/record_bag/test.bag >record_bag.log 2>&1 &
  73. ## 设置终点并执行
  74. nohup bash -c "$command" >/dev/null 2>&1 &
  75. elif [ "$DEFAULT_END_FLAG" == "false" ]; then
  76. # 自定义终点
  77. echo "Setting end point: $END_POINT"
  78. ## 发布自定义终点
  79. command="cd $SIMULATION_PATH/catkin_ws && rm -r build devel && catkin_make && source devel/setup.bash && rosrun goal_publish goal $END_POINT"
  80. ## 录包
  81. ### 激活conda环境
  82. # source activate simulation
  83. ## 清除环境
  84. pkill -f "goal_publish/goal"
  85. pkill -f "goal_publish/pub_node"
  86. pkill -f "rosbag_record"
  87. sleep 1
  88. echo 'bash -c '\""$command"\"
  89. nohup python "$SIMULATION_PATH"/rosbag_record.py "$SIMULATION_PATH"/data/record_bag/test.bag >/dev/null 2>&1 &
  90. nohup bash -c "$command" >/dev/null 2>&1 &
  91. ## 设置终点并执行
  92. echo "End point: $END_POINT has been set"
  93. fi
  94. # 是否加载障碍物
  95. if [ "$OBSTACLE_FLAG" == "true" ]; then # 加载
  96. echo "Loading default obstacle..."
  97. # 动态加载障碍物
  98. command="cd $SIMULATION_PATH/pji_work && source devel/setup.bash && rosrun test demo $SIMULATION_PATH/merge_obstacles_data/merged_obstacles_new_0517_1.csv"
  99. nohup bash -c "$command" >/dev/null 2>&1 &
  100. # gnome-terminal --tab -e 'bash -c '\""$command"\"
  101. sleep 0.5
  102. echo 'bash -c '"$command"
  103. echo "Default obstacle loaded"
  104. fi