simulation-pjibot_delivery.py 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. # -*- coding: utf-8 -*-
  2. import os
  3. import time
  4. import oss2
  5. import xml.etree.ElementTree as ET
  6. import shutil
  7. import docker
  8. import logging
  9. key1 = 'pjibot_delivery/'
  10. path1 = '/scenarios1/'
  11. path2 = '/mnt/disk001/dcl_data_process/src/python2/pjibot_delivery/'
  12. path3 = '/mnt/disk001/simulation_outdoor/'
  13. xodr = 'thq_1116.xodr'
  14. osgb = 'thq_1116.opt.osgb'
  15. vehicle_name = 'PuJin_distribution' # 配送 PuJin_distribution 巡检 PuJin_patrol_robot
  16. xoscName = 'scenario.xosc'
  17. logging.basicConfig(filename=path2 + 'log/simulation.log', level=logging.INFO,
  18. format='%(asctime)s - %(levelname)s - %(message)s')
  19. sleep_time = 60 # 每多少秒扫描一次
  20. def move_xosc_before_simulation(root_path):
  21. try:
  22. xodr = 'thq_20240706.xodr'
  23. osgb = 'thq_20230710.osgb'
  24. tree1 = ET.parse(root_path + 'scenario_orig.xosc')
  25. root1 = tree1.getroot()
  26. for node0 in root1:
  27. if node0.tag == 'RoadNetwork':
  28. for node1 in node0:
  29. # 打印根元素的标签名
  30. src_file_prefix = path3
  31. if 'LogicFile' == node1.tag:
  32. if xodr in node1.get('filepath'):
  33. dst_file = root_path + xodr
  34. shutil.copy(src_file_prefix + xodr, dst_file)
  35. node1.set('filepath', dst_file)
  36. if xodr in node1.get('filepath'):
  37. dst_file = root_path + xodr
  38. shutil.copy(src_file_prefix + xodr, dst_file)
  39. node1.set('filepath', dst_file)
  40. if xodr in node1.get('filepath'):
  41. dst_file = root_path + xodr
  42. shutil.copy(src_file_prefix + xodr, dst_file)
  43. node1.set('filepath', dst_file)
  44. if 'SceneGraphFile' == node1.tag:
  45. if osgb in node1.get('filepath'):
  46. dst_file = root_path + osgb
  47. shutil.copy(src_file_prefix + osgb, dst_file)
  48. node1.set('filepath', dst_file)
  49. if osgb in node1.get('filepath'):
  50. dst_file = root_path + osgb
  51. shutil.copy(src_file_prefix + osgb, dst_file)
  52. node1.set('filepath', dst_file)
  53. if osgb in node1.get('filepath'):
  54. dst_file = root_path + osgb
  55. shutil.copy(src_file_prefix + osgb, dst_file)
  56. node1.set('filepath', dst_file)
  57. if node0.tag == 'Entities':
  58. for node1 in node0:
  59. if node1.get("name") == 'Ego':
  60. for node2 in node1:
  61. if node2.tag == 'Vehicle':
  62. node2.set('name', vehicle_name)
  63. tree1.write(root_path + 'openx0.xosc')
  64. except Exception as e:
  65. logging.exception("修改xosc报错: %s" % str(e))
  66. def upload_simulation(parse_prefix, mp41):
  67. try:
  68. # 上传两次吧,对应上
  69. bucket.put_object_from_file(parse_prefix + 'scenario_orig.mp4', mp41)
  70. bucket.put_object_from_file(parse_prefix + 'scenario_hmi.mp4', mp41)
  71. logging.info('上传仿真视频到 %s' % parse_prefix + 'scenario_orig.mp4')
  72. shutil.rmtree(path1) # 仿真完就删除
  73. except Exception as e:
  74. logging.exception("上传视频报错 %s" % str(e))
  75. def simulation(parse_prefix, mp41):
  76. try:
  77. os.system("docker start vtd1")
  78. # 实例化Docker客户端
  79. client = docker.from_env()
  80. while True:
  81. time.sleep(5)
  82. # 获取容器列表
  83. containers = client.containers.list()
  84. run = False
  85. # 打印容器列表
  86. for container in containers:
  87. if 'vtd1' == container.name:
  88. run = True
  89. break
  90. if not run:
  91. break
  92. time.sleep(5)
  93. upload_simulation(parse_prefix, mp41)
  94. except Exception as e:
  95. logging.exception("生成仿真视频报错 %s" % str(e))
  96. def is_upload_completed(bucket, prefix):
  97. target_number = str(prefix).split('_')[-1][:-1]
  98. count = 0
  99. for obj in oss2.ObjectIterator(bucket, prefix=prefix):
  100. if obj.key != prefix:
  101. count += 1
  102. return int(count) == int(target_number)
  103. '''
  104. cname:http://open-bucket.oss.icvdc.com
  105. keyid:n8glvFGS25MrLY7j
  106. secret:xZ2Fozoarpfw0z28FUhtg8cu0yDc5d
  107. oss桶名: oss://open-bucket
  108. oss桶名: open-bucket
  109. 内网endpoint: oss-cn-beijing-gqzl-d01-a.ops.gqzl-cloud.com
  110. '''
  111. # ------- 获取合并之后的bag包,解析出csv -------
  112. if __name__ == '__main__':
  113. # 1 创建阿里云对象
  114. auth = oss2.Auth('n8glvFGS25MrLY7j', 'xZ2Fozoarpfw0z28FUhtg8cu0yDc5d')
  115. endpoint = 'oss-cn-beijing-gqzl-d01-a.ops.gqzl-cloud.com'
  116. bucket = oss2.Bucket(auth, endpoint, 'pji-bucket1')
  117. while True:
  118. try:
  119. logging.info("开始新一轮扫描")
  120. local_delete_list = []
  121. oss_delete_list = []
  122. prefix_list = []
  123. # 2 获取已经上传完成的所有目录并分组
  124. for obj1 in oss2.ObjectIterator(bucket, prefix=key1):
  125. try:
  126. # 获取合并后的包
  127. merged_bag_object_key = str(obj1.key)
  128. if 'data_merge' in str(obj1.key) and str(obj1.key).endswith('.bag'):
  129. merged_bag_object_key_split = merged_bag_object_key.split('/')
  130. merged_prefix = '/'.join(merged_bag_object_key_split[:-1])
  131. parse_prefix = merged_prefix.replace('data_merge', 'data_parse')
  132. parse_prefix_full = merged_bag_object_key.replace('data_merge', 'data_parse')[:-4] + '/'
  133. xosc_done = False
  134. mp4_done = False
  135. for obj3 in oss2.ObjectIterator(bucket, prefix=str(parse_prefix_full)):
  136. if xoscName in str(obj3.key):
  137. xosc_done = True
  138. if '/scenario_orig.mp4' in str(obj3.key):
  139. mp4_done = True
  140. if not xosc_done:
  141. continue
  142. if mp4_done:
  143. continue
  144. logging.info("需要生成仿真视频: %s" % str(parse_prefix_full))
  145. parse_prefix_full = str(parse_prefix_full)
  146. local_dir_full = path1 + parse_prefix_full
  147. if not os.path.exists(local_dir_full):
  148. os.makedirs(local_dir_full)
  149. # 下载两个csv
  150. root_path1 = local_dir_full + 'orig/'
  151. if not os.path.exists(root_path1):
  152. os.makedirs(root_path1)
  153. bucket.get_object_to_file(parse_prefix_full + xoscName, root_path1 + 'scenario_orig.xosc')
  154. local_delete_list.append(root_path1 + 'scenario_orig.xosc')
  155. move_xosc_before_simulation(root_path1)
  156. simulation(parse_prefix_full, root_path1 + 'simulation.mp4')
  157. except Exception as e:
  158. logging.exception("局部异常处理: %s", str(e))
  159. # 删除本地临时文件
  160. if len(local_delete_list) > 0:
  161. for local_delete in local_delete_list:
  162. try:
  163. os.remove(local_delete)
  164. except Exception as e:
  165. pass
  166. time.sleep(sleep_time)
  167. except Exception as e:
  168. logging.exception("全局异常处理: %s", str(e))