run_simulation.sh 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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. # /home/cicv/work/pji_desktop/simulation/data/build_map_bag/build_map.bag \
  25. # # 默认起点配置
  26. # python "$SIMULATION_PATH"/catkin_ws/src/goal_publish/script/send_initial_pos_0521.py \
  27. # "$SIMULATION_PATH"/data/map_bag/"$MAP_BAG_NAME" \
  28. # "$SIMULATION_PATH"/catkin_ws/src/SimulationEnvs/launch/env_node.launch \
  29. # "$SIMULATION_PATH"/catkin_ws/src/Navigation/launch/amcl.launch
  30. # sleep 1
  31. elif [ "$DEFAULT_START_FLAG" == "false" ]; then
  32. # 自定义起点
  33. echo "Setting start point: $START_POINT"
  34. ## 发布自定义起点 - gazebo
  35. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish initialPose $START_POINT"
  36. ### 清除环境
  37. pkill -f "goal_publish/initialPose"
  38. sleep 1
  39. echo 'bash -c '\""$command"\"
  40. nohup bash -c "$command" >/dev/null 2>&1 &
  41. sleep 1
  42. ## 发布自定义起点 - rviz
  43. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish initialPose_rviz $START_POINT"
  44. ### 清除环境
  45. pkill -f "goal_publish/initialPose_rviz"
  46. sleep 1
  47. echo 'bash -c '\""$command"\"
  48. nohup bash -c "$command" >/dev/null 2>&1 &
  49. ### 这里必须设置不少于5s的延迟时间,否则rviz中的起点设置会出现问题
  50. sleep 5
  51. echo "Start point: $START_POINT has been set"
  52. fi
  53. # 终点设置
  54. if [ "$DEFAULT_END_FLAG" == "true" ]; then
  55. # 默认终点
  56. echo "Use default end point"
  57. ## 发布默认终点
  58. # 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"
  59. 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/evaluation_bag/example_0821_4.bag"
  60. ## 录包
  61. ### 激活conda环境
  62. # source activate simulation
  63. # nohup python "$SIMULATION_PATH"/rosbag_record.py "$SIMULATION_PATH"/data/record_bag/test.bag >/dev/null 2>&1 &
  64. ## 清除环境
  65. pkill -f "goal_publish/goal" # 下发自定义/默认终点前必须先清除goal,不能只清除pub_node
  66. pkill -f "goal_publish/pub_node"
  67. pkill -f "rosbag_record"
  68. sleep 1
  69. echo 'bash -c '\""$command"\"
  70. nohup python "$SIMULATION_PATH"/rosbag_record.py "$SIMULATION_PATH"/data/record_bag/test.bag >record_bag.log 2>&1 &
  71. ## 设置终点并执行
  72. nohup bash -c "$command" >/dev/null 2>&1 &
  73. elif [ "$DEFAULT_END_FLAG" == "false" ]; then
  74. # 自定义终点
  75. echo "Setting end point: $END_POINT"
  76. ## 发布自定义终点
  77. command="cd $SIMULATION_PATH/catkin_ws && rm -r build devel && catkin_make && source devel/setup.bash && rosrun goal_publish goal $END_POINT"
  78. ## 录包
  79. ### 激活conda环境
  80. # source activate simulation
  81. ## 清除环境
  82. pkill -f "goal_publish/goal"
  83. pkill -f "goal_publish/pub_node"
  84. pkill -f "rosbag_record"
  85. sleep 1
  86. echo 'bash -c '\""$command"\"
  87. nohup python "$SIMULATION_PATH"/rosbag_record.py "$SIMULATION_PATH"/data/record_bag/test.bag >/dev/null 2>&1 &
  88. nohup bash -c "$command" >/dev/null 2>&1 &
  89. ## 设置终点并执行
  90. echo "End point: $END_POINT has been set"
  91. fi
  92. # 是否加载障碍物
  93. if [ "$OBSTACLE_FLAG" == "true" ]; then # 加载
  94. echo "Loading default obstacle..."
  95. # 动态加载障碍物
  96. command="cd $SIMULATION_PATH/pji_work && source devel/setup.bash && rosrun test demo $SIMULATION_PATH/merge_obstacles_data/merged_obstacles_new_0517_1.csv"
  97. nohup bash -c "$command" >/dev/null 2>&1 &
  98. # gnome-terminal --tab -e 'bash -c '\""$command"\"
  99. sleep 0.5
  100. echo 'bash -c '"$command"
  101. echo "Default obstacle loaded"
  102. fi