run_simulation.sh 7.3 KB

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