123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604 |
- """
- tips:
- 推算半径:13.7
- 倒车与正开的偏移量是5米;倒车中心点=正开中心点+5
- """
- # 坐标数据文件
- data_file_dir = '../data'
- data_file_path = '../data/渣罐坐标数据.json'
- # data_file_path = '/home/ubuntu/repositories/repositories/casperz.py-project/project-fastapi-hs/data/渣罐坐标数据.json'
- # data_file_path = r"E:\casper\repositories\repositories\casperz.py-project\project-fastapi-hs\data\渣罐坐标数据.json"
- # 道路名称列表
- path_name_list = [
- 'MN',
- 'KL',
- 'IJ',
- 'GH',
- 'EF',
- 'CD',
- 'AB',
- ]
- # 渣罐坐标字典
- d4 = {
- # 停车区坐标
- 'pack.1': {'point': (11, 22)},
- 'pack.2': {'point': (11, 22)},
- # 接渣口坐标
- 'load.1': {'point': (11, 22)},
- 'load.2': {'point': (11, 22)},
- 'load.3': {'point': (11, 22)},
- # 倒渣口坐标
- 'dump.MN': {'point': (11, 205.75)}, # 1号倒渣口
- 'dump.KL': {'point': (11, 177.75)}, # 2号倒渣口
- 'dump.IJ': {'point': (11, 149.75)}, # 3号倒渣口
- 'dump.GH': {'point': (11, 121.75)}, # 4号倒渣口
- 'dump.EF': {'point': (11, 93.75)}, # 5号倒渣口
- 'dump.CD': {'point': (11, 65.75)}, # 6号倒渣口
- 'dump.AB': {'point': (11, 37.75)}, # 7号倒渣口
- # 渣罐位坐标
- 'M.31': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.30': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.29': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.28': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.27': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.26': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.25': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.24': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.23': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.22': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.21': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.20': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.19': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.18': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.17': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.16': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.15': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.14': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.13': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.12': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.11': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.10': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.9': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.8': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.7': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.6': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.5': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.4': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.3': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.2': {'pot': (22, 33), 'road_center': (44, 55)},
- 'M.1': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.31': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.30': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.29': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.28': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.27': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.26': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.25': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.24': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.23': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.22': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.21': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.20': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.19': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.18': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.17': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.16': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.15': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.14': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.13': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.12': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.11': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.10': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.9': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.8': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.7': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.6': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.5': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.4': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.3': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.2': {'pot': (22, 33), 'road_center': (44, 55)},
- 'F.1': {'pot': (22, 33), 'road_center': (44, 55)},
- }
- def get_nearest_point_name_from_pot_point(current_x, current_y):
- """
- 获取当前位置距离最忌的罐体位置名称
- """
- current_x = float(current_x)
- current_y = float(current_y)
- min_distance = float('inf') # 初始值无穷大
- nearest_point_name = str() # 最近点名称
- # --- check road center ---
- for k, v in d4.items():
- if 'pack' in k or 'load' in k or 'dump' in k:
- continue
- point_x = float(v.get('road_center')[0])
- point_y = float(v.get('road_center')[1])
- distance = ((point_x - current_x) ** 2 + (point_y - current_y) ** 2) ** (1 / 2)
- if distance < min_distance:
- min_distance = distance
- nearest_point_name = k
- # --- check dump port ---
- for k, v in d4.items():
- if 'dump' not in k:
- continue
- point_x = float(v.get('point')[0])
- point_y = float(v.get('point')[1])
- distance = ((point_x - current_x) ** 2 + (point_y - current_y) ** 2) ** (1 / 2)
- if distance < min_distance:
- min_distance = distance
- nearest_point_name = k
- return nearest_point_name
- def get_nearest_point_from_road_center_point(x, y):
- """
- 获取当前所在位置最接近的坐标位置
- """
- x = float(x)
- y = float(y)
- min_distance = float('inf') # 初始值无穷大
- for k, v in d4.items():
- center_x = float(v.get('road_center')[0])
- center_y = float(v.get('road_center')[1])
- distance = ((center_x - x) ** 2 + (center_y - y) ** 2) ** (1 / 2)
- if distance < min_distance:
- min_distance = distance
- nearest_point = center_x, center_y
- return nearest_point
- def get_corner_point(w1='N', w2='head'):
- """获取拐弯点"""
- if w2 == 'head':
- return d4.get(f"{w1}.{1}").get('road_center')
- elif w2 == 'tail':
- return d4.get(f"{w1}.{31}").get('road_center')
- def get_path_name_by_pot_name(pot_name='M.25'):
- """根据渣罐名获取道路名"""
- s1, s2 = pot_name.split('.')
- for s in path_name_list:
- if s1 in s:
- return s
- def get_path_name_by_dump_name(dump_name='dump.MN'):
- """根据渣罐名获取道路名"""
- _, s2 = dump_name.split('.')
- return s2
- import json
- def test(current_direction_type=3, start_x=11, start_y=22, target_point_name='M.1'):
- """
- current_direction_type: 起始方向 3 围栏方向 9 渣场方向 12 维修间方向 6 维修间正对方向 0 未知(默认值)
- s_name: 起始位置
- e_name: 目标位置
- """
- # --- update d4 ---
- data = json.load(open(data_file_path, 'rb'))
- for item in data.get('pot_name|pot_x|pot_y|road_center_x|road_center_y'):
- pot_name, pot_x, pot_y, road_center_x, road_center_y = item.split('|')
- d4[pot_name] = {
- 'pot': (float(pot_x), float(pot_y)),
- 'road_center': (float(road_center_x), float(road_center_y)),
- }
- # --- update d4 ---
- data = json.load(open(f"{data_file_dir}/倒渣口坐标数据.json", 'rb'))
- for item in data.get('name|x|y'):
- name, x, y = item.split('|')
- d4[name] = {
- 'point': (float(x), float(y)),
- }
- # --- check ---
- if not start_x and not start_y:
- return "Reason: 参数缺失"
- # --- check ---
- if current_direction_type not in [3, 9]:
- return "Reason: 暂不支持"
- # --- define ---
- current_point_name = get_nearest_point_name_from_pot_point(start_x, start_y)
- s_point_item = dict(**d4.get(current_point_name), **{'name': current_point_name})
- e_point_item = dict(**d4.get(target_point_name), **{'name': target_point_name})
- # --- define ---
- radius = 14 # 转弯半径
- s_s1, s_s2 = current_point_name.split('.')
- e_s1, e_s2 = target_point_name.split('.')
- print(f"current_point_name: {current_point_name}")
- print(f"target_point_name: {target_point_name}")
- # --- check ---
- if 'dump' not in current_point_name and 'dump' not in target_point_name:
- if current_direction_type == 9 and s_s1 == e_s1 and int(s_s2) > int(e_s2):
- """
- 情况1:判断是否是在正前方的情况1
- """
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': [
- {
- # 直行轨迹坐标参数
- 'start_point_x': s_point_item.get('road_center')[0],
- 'start_point_y': s_point_item.get('road_center')[1],
- 'end_point_x': e_point_item.get('road_center')[0],
- 'end_point_y': e_point_item.get('road_center')[1],
- },
- ],
- }
- ]
- elif current_direction_type == 3 and s_s1 == e_s1 and int(s_s2) < int(e_s2):
- """
- 情况2:判断是否是在正前方的情况2
- """
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': [
- # 直线行驶
- {
- 'start_point_x': s_point_item.get('road_center')[0],
- 'start_point_y': s_point_item.get('road_center')[1],
- 'end_point_x': e_point_item.get('road_center')[0],
- 'end_point_y': e_point_item.get('road_center')[1],
- },
- ],
- }
- ]
- elif current_direction_type == 9 and s_s1 > e_s1:
- """
- 情况3:车头9方向,向9点6点3点行驶(共2个弯,1个是出弯,1个是入弯)
- """
- path_name = get_path_name_by_pot_name(current_point_name)
- corner_name = path_name[:1] # 拐弯点(9点到6点方向转弯)(取首位)
- corner_point_1 = get_corner_point(w1=corner_name, w2='head')
- corner_point_1_x = corner_point_1[0]
- corner_point_1_y = corner_point_1[1]
- path_name = get_path_name_by_pot_name(target_point_name)
- corner_name = path_name[-1:] # 拐弯点(6点到3点方向转弯)(取末位)
- corner_point_2 = get_corner_point(w1=corner_name, w2='head')
- corner_point_2_x = corner_point_2[0]
- corner_point_2_y = corner_point_2[1]
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': [
- # 直线行驶
- {
- 'start_point_x': s_point_item.get('road_center')[0], # 起始点坐标
- 'start_point_y': s_point_item.get('road_center')[1], # 起始点坐标
- 'end_point_x': corner_point_1_x, # 入弯坐标
- 'end_point_y': corner_point_1_y, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_1_x, # 入弯坐标
- "start_point_y": corner_point_1_y, # 入弯坐标
- "center_point_x": corner_point_1_x, # 圆心坐标
- "center_point_y": corner_point_1_y - radius, # 圆心坐标
- "end_point_x": corner_point_1_x - radius, # 出弯坐标
- "end_point_y": corner_point_1_y - radius, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_1_x - radius, # 出弯坐标
- 'start_point_y': corner_point_1_y - radius, # 出弯坐标
- 'end_point_x': corner_point_2_x - radius, # 入弯坐标
- 'end_point_y': corner_point_2_y + radius, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_2_x - radius, # 入弯坐标
- "start_point_y": corner_point_2_y + radius, # 入弯坐标
- "center_point_x": corner_point_2_x, # 圆心坐标
- "center_point_y": corner_point_2_y + radius, # 圆心坐标
- "end_point_x": corner_point_2_x, # 出弯坐标
- "end_point_y": corner_point_2_y, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_2_x, # 出弯坐标
- 'start_point_y': corner_point_2_y, # 出弯坐标
- 'end_point_x': e_point_item.get('road_center')[0], # 目标点坐标
- 'end_point_y': e_point_item.get('road_center')[1], # 目标点坐标
- },
- ],
- }
- ]
- elif current_direction_type == 9 and s_s1 == e_s1 and int(s_s2) < int(e_s2):
- """
- 情况5:判断是否是在正后方的情况1 M.3 -> M.10(共2个弯)
- """
- path_name = get_path_name_by_pot_name(current_point_name)
- corner_name = path_name[:1] # 拐弯点(9点到6点方向转弯)(取首位)
- corner_point_1 = get_corner_point(w1=corner_name, w2='head')
- corner_point_1_x = corner_point_1[0]
- corner_point_1_y = corner_point_1[1]
- corner_point_2 = get_corner_point(w1=corner_name, w2='tail')
- corner_point_2_x = corner_point_2[0]
- corner_point_2_y = corner_point_2[0]
- # print(f"corner_point_1: {corner_point_1}")
- # print(f"corner_point_2: {corner_point_2}")
- # return "Result: 正在开发"
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': [
- # 直线行驶
- {
- 'start_point_x': s_point_item.get('road_center')[0], # 起始点坐标
- 'start_point_y': s_point_item.get('road_center')[1], # 起始点坐标
- 'end_point_x': corner_point_1_x, # 入弯坐标
- 'end_point_y': corner_point_1_y, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_1_x, # 入弯坐标
- "start_point_y": corner_point_1_y, # 入弯坐标
- "center_point_x": corner_point_1_x, # 圆心坐标
- "center_point_y": corner_point_1_y - radius, # 圆心坐标
- "end_point_x": corner_point_1_x, # 出弯坐标
- "end_point_y": corner_point_1_y - radius - radius, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_1_x, # 出弯坐标
- 'start_point_y': corner_point_1_y - radius - radius, # 出弯坐标
- 'end_point_x': corner_point_2_x, # 入弯坐标
- 'end_point_y': corner_point_2_y - radius - radius, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_2_x, # 入弯坐标
- "start_point_y": corner_point_2_y - radius - radius, # 入弯坐标
- "center_point_x": corner_point_2_x, # 圆心坐标
- "center_point_y": corner_point_2_y - radius, # 圆心坐标
- "end_point_x": corner_point_2_x, # 出弯坐标
- "end_point_y": corner_point_2_y, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_2_x, # 出弯坐标
- 'start_point_y': corner_point_2_y, # 出弯坐标
- 'end_point_x': e_point_item.get('road_center')[0], # 目标点坐标
- 'end_point_y': e_point_item.get('road_center')[1], # 目标点坐标
- },
- ]
- }
- ]
- else:
- return "Result: 暂不支持"
- elif 'dump' not in current_point_name and 'dump' in target_point_name:
- if current_direction_type == 9:
- """
- 情况4:渣罐位,车头9点方向,6点拐弯,3点拐弯,倒车倒入指定倒渣口
- """
- path_name = get_path_name_by_pot_name(current_point_name)
- # print(f"path_name: {path_name}")
- corner_name = path_name[:1] # 拐弯点(9点到6点方向转弯)(取首位)
- corner_point_1 = get_corner_point(w1=corner_name, w2='head')
- corner_point_1_x = corner_point_1[0]
- corner_point_1_y = corner_point_1[1]
- # print(f"corner_point_1: {corner_point_1}")
- path_name = get_path_name_by_dump_name(target_point_name)
- corner_name = path_name[-1:] # 拐弯点(6点到3点方向转弯)(取末位)
- corner_point_2 = get_corner_point(w1=corner_name, w2='head')
- corner_point_2_x = corner_point_2[0]
- corner_point_2_y = corner_point_2[1]
- # print(f"corner_point_2: {corner_point_2}")
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': [
- # 直线行驶
- {
- 'start_point_x': s_point_item.get('road_center')[0], # 起始点坐标
- 'start_point_y': s_point_item.get('road_center')[1], # 起始点坐标
- 'end_point_x': corner_point_1_x, # 入弯坐标
- 'end_point_y': corner_point_1_y, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_1_x, # 入弯坐标
- "start_point_y": corner_point_1_y, # 入弯坐标
- "center_point_x": corner_point_1_x, # 圆心坐标
- "center_point_y": corner_point_1_y - radius, # 圆心坐标
- "end_point_x": corner_point_1_x - radius, # 出弯坐标
- "end_point_y": corner_point_1_y - radius, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_1_x - radius, # 出弯坐标
- 'start_point_y': corner_point_1_y - radius, # 出弯坐标
- 'end_point_x': corner_point_2_x - radius, # 入弯坐标
- 'end_point_y': corner_point_2_y + radius, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_2_x - radius, # 入弯坐标
- "start_point_y": corner_point_2_y + radius, # 入弯坐标
- "center_point_x": corner_point_2_x, # 圆心坐标
- "center_point_y": corner_point_2_y + radius, # 圆心坐标
- "end_point_x": corner_point_2_x, # 出弯坐标
- "end_point_y": corner_point_2_y, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_2_x, # 出弯坐标
- 'start_point_y': corner_point_2_y, # 出弯坐标
- 'end_point_x': corner_point_2_x + 30, # 前进30米,摆正车身,为倒车准备
- 'end_point_y': corner_point_2_y, # 摆正车身,为倒车准备
- },
- ]
- },
- {
- 'type': 'backward',
- 'nav_coordinates': [
- # 直线行驶
- {
- 'start_point_x': corner_point_2_x + 30, # 前进30米,摆正车身,为倒车准备
- 'start_point_y': corner_point_2_y, # 摆正车身,为倒车准备
- 'end_point_x': e_point_item.get('point')[0], # 倒渣口坐标
- 'end_point_y': e_point_item.get('point')[1], # 倒渣口坐标
- },
- ]
- }
- ]
- else:
- return "Result: 暂不支持"
- elif 'dump' in current_point_name and 'dump' not in target_point_name and current_direction_type == 3:
- if e_s1 in s_s2:
- """
- 情况6:倒渣位,车头3点方向,目标点正对目标巷道情况
- """
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': [
- # 直线行驶
- {
- 'start_point_x': s_point_item.get('point')[0], # 起始点坐标
- 'start_point_y': s_point_item.get('point')[1], # 起始点坐标
- 'end_point_x': e_point_item.get('road_center')[0], # 目标点坐标
- 'end_point_y': e_point_item.get('road_center')[1], # 目标点坐标
- },
- ]
- }
- ]
- elif e_s1 > s_s2[1]:
- """
- 情况7:倒渣位,车头3点方向,目标点位于巷道上侧
- """
- path_name = get_path_name_by_dump_name(current_point_name)
- corner_name = path_name[-1:] # 拐弯点(3点->12点)(取末位)
- corner_point_1_x, corner_point_1_y = get_corner_point(w1=corner_name, w2='tail')
- path_name = get_path_name_by_pot_name(target_point_name)
- corner_name = path_name[:1] # 拐弯点(12点->9点)(取首位)
- corner_point_2_x, corner_point_2_y = get_corner_point(w1=corner_name, w2='tail')
- # print(f"corner_point_2_x: {corner_point_2_x}")
- # print(f"corner_point_2_y: {corner_point_2_y}")
- nav_coordinates_1 = [
- # 直线行驶
- {
- 'start_point_x': s_point_item.get('point')[0], # 起始点坐标
- 'start_point_y': s_point_item.get('point')[1], # 起始点坐标
- 'end_point_x': corner_point_1_x, # 入弯坐标
- 'end_point_y': corner_point_1_y, # 入弯坐标
- },
- # 转弯行驶
- {
- "start_point_x": corner_point_1_x, # 入弯坐标
- "start_point_y": corner_point_1_y, # 入弯坐标
- "center_point_x": corner_point_1_x, # 圆心坐标
- "center_point_y": corner_point_1_y + radius, # 圆心坐标
- "end_point_x": corner_point_1_x + radius, # 出弯坐标
- "end_point_y": corner_point_1_y + radius, # 出弯坐标
- },
- ]
- nav_coordinates_2 = [
- # 直线行驶
- {
- 'start_point_x': corner_point_1_x + radius, # 出弯坐标
- 'start_point_y': corner_point_1_y + radius, # 出弯坐标
- 'end_point_x': corner_point_2_x + radius, # 入弯坐标
- 'end_point_y': corner_point_2_y - radius, # 入弯坐标
- }
- ]
- # --- check ---
- if (corner_point_1_x + radius == corner_point_2_x + radius
- or corner_point_1_y + radius == corner_point_2_y - radius):
- nav_coordinates_2 = []
- nav_coordinates_3 = [
- # 转弯行驶
- {
- "start_point_x": corner_point_2_x + radius, # 入弯坐标
- "start_point_y": corner_point_2_y - radius, # 入弯坐标
- "center_point_x": corner_point_2_x, # 圆心坐标
- "center_point_y": corner_point_2_y - radius, # 圆心坐标
- "end_point_x": corner_point_2_x, # 出弯坐标
- "end_point_y": corner_point_2_y, # 出弯坐标
- },
- # 直线行驶
- {
- 'start_point_x': corner_point_2_x, # 出弯坐标
- 'start_point_y': corner_point_2_y, # 出弯坐标
- 'end_point_x': e_point_item.get('road_center')[0], # 目标点坐标
- 'end_point_y': e_point_item.get('road_center')[1], # 目标点坐标
- }
- ]
- return [
- {
- 'type': 'forward',
- 'nav_coordinates': nav_coordinates_1 + nav_coordinates_2 + nav_coordinates_3
- }
- ]
- elif e_s1 < s_s2[0]:
- """
- 情况8:倒渣位,车头3点方向,目标点位于巷道下侧
- """
- return "Result: 暂不支持 222"
- else:
- return "Result: 暂不支持"
- return "Result: 暂不支持"
- else:
- return "Result: 暂不支持"
- if __name__ == '__main__':
- # --- 现场实际测试数据 ---
- offset = 6.4
- M01 = 14.450 + (offset * 0), 199.64
- M31 = 184.93 - (offset * 6), 195.7
- M03 = 35.5, 205.75
- M12 = 85, 205.75
- # --- cad理论测试数据 ---
- dumpCD = 4.18, 65.75
- # 情况1:判断是否是在正前方的情况1 M.10 -> M.2
- # out = test(current_direction_type=9, start_x=M31[0], start_y=M31[1], target_point_name='M.1')
- # 情况2:判断是否是在正前方的情况2 M.12 -> M.20
- # out = test(current_direction_type=3, start_x=M12[0], start_y=M12[1], target_point_name='M.20')
- # 情况3:车头9方向,向6点行驶,并拐弯情况(共2个弯,1个是出弯,1个是入弯)
- # out = test(current_direction_type=9, start_x=M12[0], start_y=M12[1], target_point_name='F.20')
- # 情况4:渣罐位,车头9点方向,6点拐弯,3点拐弯,倒车倒入指定倒渣口
- # out = test(current_direction_type=9, start_x=M31[0], start_y=M31[1], target_point_name='dump.CD')
- # out = test(current_direction_type=9, start_x=M03[0], start_y=M03[1], target_point_name='dump.CD')
- # 情况5:判断是否是在正后方的情况1 M.3 -> M.10(共2个弯)
- # out = test(current_direction_type=9, start_x=M01[0], start_y=M01[1], target_point_name='M.10')
- # out = test(current_direction_type=9, start_x=M03[0], start_y=M03[1], target_point_name='M.10')
- # 情况6:倒渣位,车头3点方向,目标点正对目标巷道情况
- # out = test(current_direction_type=3, start_x=dumpCD[0], start_y=dumpCD[1], target_point_name='D.20')
- # 情况7:倒渣位,车头3点方向,目标点位于巷道上侧
- # out = test(current_direction_type=3, start_x=dumpCD[0], start_y=dumpCD[1], target_point_name='M.1')
- # 情况8:倒渣位,车头3点方向,目标点位于巷道下侧 todo 存在一上来就转弯,有个圆心怎么算呢
- # out = test(current_direction_type=3, start_x=dumpCD[0], start_y=dumpCD[1], target_point_name='A.30')
- print(out)
- # --- test ---
- # out = get_nearest_point_name_from_pot_point(dumpCD[0], dumpCD[1])
- # print(out)
|