run_simulation.sh 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. #!/bin/bash
  2. # 检查到未定义的变量则停止执行并报错
  3. set -u
  4. # 检查参数数量
  5. if [ "$#" -ne 7 ]; then
  6. echo "Error: Incorrect number of arguments"
  7. echo "Usage: $0 RANDOM_FLAG COUNT OBSTACLE_FLAG DEFAULT_START_FLAG DEFAULT_END_FLAG START_POINT END_POINT"
  8. exit 1
  9. fi
  10. RANDOM_FLAG=$1
  11. COUNT=$2
  12. OBSTACLE_FLAG=$3
  13. DEFAULT_START_FLAG=$4
  14. DEFAULT_END_FLAG=$5
  15. START_POINT=$(echo "$6" | tr ',' ' ')
  16. END_POINT=$(echo "$7" | tr ',' ' ')
  17. MAP_BAG_NAME="origin_map.bag"
  18. SIMULATION_PATH="/home/cicv/work/pji_desktop/simulation"
  19. SIMULATION_RANDOM_LOG_PATH="$SIMULATION_PATH/logs/simulation_random.log"
  20. SIMULATION_CUSTOM_LOG_PATH="$SIMULATION_PATH/logs/simulation_custom.log"
  21. RECORD_BAG_LOG_PATH="$SIMULATION_PATH/logs/record_bag.log"
  22. RECORD_BAG_FINISH_FLAG="killing the process"
  23. EVALUATION_FINISH_FLAG="Evaluation finished"
  24. # 自定义起终点,数量重置为1
  25. if [ "$RANDOM_FLAG" == "false" ]; then
  26. COUNT=1
  27. fi
  28. # 激活conda环境
  29. source activate simulation
  30. # 清除历史文件
  31. ## 删除录制的rosbag
  32. safe-rm -f "${SIMULATION_PATH:?}"/data/record_bag/* # ${var:?}避免删除其他位置的文件,当变量不存在时会报错,而不是误删除根目录的文件
  33. ## 删除历史日志
  34. if [ -f "$RECORD_BAG_LOG_PATH" ]; then
  35. safe-rm "$RECORD_BAG_LOG_PATH"
  36. fi
  37. if [ -f "$SIMULATION_RANDOM_LOG_PATH" ]; then
  38. safe-rm "$SIMULATION_RANDOM_LOG_PATH"
  39. fi
  40. if [ -f "$SIMULATION_CUSTOM_LOG_PATH" ]; then
  41. safe-rm "$SIMULATION_CUSTOM_LOG_PATH"
  42. fi
  43. # 判断是否为随机起终点
  44. if [ "$RANDOM_FLAG" == "true" ]; then # 随机起终点
  45. echo "Use random start/end point"
  46. command="cd $SIMULATION_PATH/random_install && source install/setup.bash && rosrun random_point random_point $SIMULATION_PATH/data/mapBuf $COUNT"
  47. # 清除环境
  48. pkill -f "rosbag_record"
  49. pkill -f "random_point"
  50. sleep 0.5
  51. # 执行命令
  52. nohup script -q -c bash -c "$command" > "$SIMULATION_RANDOM_LOG_PATH" 2>&1 &
  53. disown
  54. # 录包
  55. command="python $SIMULATION_PATH/rosbag_record.py $SIMULATION_PATH/data/record_bag $COUNT"
  56. nohup script -q -c bash -c "$command" > "$RECORD_BAG_LOG_PATH" 2>&1 &
  57. disown
  58. elif [ "$RANDOM_FLAG" == "false" ]; then # 给定起终点
  59. # 起点设置
  60. if [ "$DEFAULT_START_FLAG" == "true" ]; then
  61. # 默认起点
  62. echo "Use default start point"
  63. ## 配置默认起点
  64. command="cd $SIMULATION_PATH/custom_point && source install/setup.bash && rosrun goal_publish custom $SIMULATION_PATH/data/map_bag/$MAP_BAG_NAME"
  65. ### 清除环境
  66. pkill -f "goal_publish/initialPose"
  67. pkill -f "goal_publish/custom"
  68. sleep 1
  69. echo 'bash -c '\""$command"\"
  70. nohup bash -c "$command" >/dev/null 2>&1 &
  71. sleep 1
  72. elif [ "$DEFAULT_START_FLAG" == "false" ]; then
  73. # 自定义起点
  74. echo "Setting start point: $START_POINT"
  75. ## 发布自定义起点 - gazebo
  76. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish initialPose $START_POINT"
  77. ### 清除环境
  78. pkill -f "goal_publish/initialPose"
  79. sleep 0.5
  80. echo 'bash -c '\""$command"\"
  81. nohup bash -c "$command" >/dev/null 2>&1 &
  82. sleep 1
  83. ## 发布自定义起点 - rviz
  84. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish initialPose_rviz $START_POINT"
  85. ### 清除环境
  86. pkill -f "goal_publish/initialPose_rviz"
  87. sleep 0.5
  88. echo 'bash -c '\""$command"\"
  89. nohup bash -c "$command" >/dev/null 2>&1 &
  90. ### 这里必须设置不少于5s的延迟时间,否则rviz中的起点设置会出现问题
  91. sleep 5
  92. echo "Start point: $START_POINT has been set"
  93. fi
  94. # 终点设置
  95. if [ "$DEFAULT_END_FLAG" == "true" ]; then
  96. # 默认终点
  97. echo "Use default end point"
  98. ## 发布默认终点
  99. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish pub_node $SIMULATION_PATH/data/map_bag/$MAP_BAG_NAME $SIMULATION_PATH/data/map_bag/example.bag"
  100. ## 清除环境
  101. pkill -f "goal_publish/goal" # 下发自定义/默认终点前必须先清除goal,不能只清除pub_node
  102. pkill -f "goal_publish/pub_node"
  103. pkill -f "rosbag record"
  104. sleep 1
  105. echo 'bash -c '\""$command"\"
  106. ## 录包
  107. nohup python "$SIMULATION_PATH/rosbag_record.py" "$SIMULATION_PATH/data/record_bag/" 1 > "$RECORD_BAG_LOG_PATH" 2>&1 &
  108. disown
  109. ## 设置终点并执行
  110. nohup bash -c "$command" > "$SIMULATION_CUSTOM_LOG_PATH" 2>&1 &
  111. disown
  112. elif [ "$DEFAULT_END_FLAG" == "false" ]; then
  113. # 自定义终点
  114. echo "Setting end point: $END_POINT"
  115. ## 发布自定义终点
  116. command="cd $SIMULATION_PATH/catkin_ws && catkin_make && source devel/setup.bash && rosrun goal_publish goal $END_POINT"
  117. ## 清除环境
  118. pkill -f "goal_publish/goal"
  119. pkill -f "goal_publish/pub_node"
  120. pkill -f "rosbag record"
  121. sleep 1
  122. echo 'bash -c '\""$command"\"
  123. ## 录包
  124. nohup python "$SIMULATION_PATH/rosbag_record.py" "$SIMULATION_PATH/data/record_bag/" 1 > "$RECORD_BAG_LOG_PATH" 2>&1 &
  125. disown
  126. ## 设置终点并执行
  127. nohup bash -c "$command" > "$SIMULATION_CUSTOM_LOG_PATH" 2>&1 &
  128. disown
  129. echo "End point: $END_POINT has been set"
  130. fi
  131. fi
  132. # 是否加载障碍物
  133. if [ "$OBSTACLE_FLAG" == "true" ]; then # 加载
  134. echo "Loading default obstacle..."
  135. # 动态加载障碍物
  136. command="cd $SIMULATION_PATH/pji_work && safe-rm -r build devel && catkin_make && source devel/setup.bash && rosrun test demo $SIMULATION_PATH/merge_obstacles_data/merged_obstacles_new.csv"
  137. nohup bash -c "$command" >/dev/null 2>&1 &
  138. sleep 0.5
  139. echo 'bash -c '"$command"
  140. echo "Default obstacle loaded"
  141. fi
  142. ## 检查录包是否完成 - 执行算法评价
  143. tail -F "$RECORD_BAG_LOG_PATH" | while read LINE; do
  144. echo "$LINE"
  145. # 检查录包完成标志
  146. if echo "$LINE" | grep -q "$RECORD_BAG_FINISH_FLAG"; then # 已完成
  147. # 启动算法评价
  148. ## 清理环境
  149. # killall -9 roscore # 如果提示未找到进程不用管,继续执行下一条
  150. # killall -9 rosmaster
  151. ## 清理历史文件
  152. safe-rm -rf "$SIMULATION_PATH"/data/evaluation/* # *必须在外面才代表通配符
  153. ## 配置环境
  154. cd "$SIMULATION_PATH"/track_space
  155. sudo safe-rm -rf "$SIMULATION_PATH/track_space/build" "$SIMULATION_PATH/track_space/devel"
  156. catkin_make
  157. source devel/setup.bash
  158. ## 运行roscore
  159. nohup roscore >/dev/null 2>&1 &
  160. sleep 2
  161. ## 循环评价录制的rosbag
  162. for ((i = 1; i <= COUNT; i++)); do
  163. echo "Evaluating test-$i.bag..."
  164. save_folder="$SIMULATION_PATH/data/evaluation/$i"
  165. if [ ! -d "$save_folder" ]; then
  166. echo "Creating folder: $save_folder..."
  167. mkdir -p "$save_folder"
  168. mkdir -p "$save_folder/trackPicture"
  169. mkdir -p "$save_folder/result"
  170. echo "Folder: $save_folder created successfully"
  171. fi
  172. ## 生成轨迹图片
  173. echo "Creating the track picture..."
  174. rosrun trajectory demo_node "$SIMULATION_PATH/data/map_bag/map.bag" \
  175. "$SIMULATION_PATH/data/record_bag/" \
  176. "$SIMULATION_PATH/data/evaluation/$i/trackPicture/test.png"
  177. echo "The track picture: $SIMULATION_PATH/data/evaluation/$i/trackPicture/test.png created successfully"
  178. ## 执行算法评价
  179. cd "$SIMULATION_PATH"/pji_single/run
  180. ./pji_single "$SIMULATION_PATH/data/record_bag/test-$i.bag" \
  181. "$SIMULATION_PATH/data/evaluation/$i/result" \
  182. "$SIMULATION_PATH/data/evaluation/$i/trackPicture/test.png"
  183. echo "Rosbag test-$i.bag evaluation results generated successfully"
  184. done
  185. echo "$EVALUATION_FINISH_FLAG"
  186. break
  187. fi
  188. done