OSM: Как получить знаки остановки или светофоры на заданном GPS-треке?

Я новичок в теме OSM. Я использую python и openrouteservice API и / или машину маршрутизации с открытым исходным кодом для маршрутизации между несколькими местоположениями и получения GPS-трека. Для ORS я получаю только точки широты и долготы, а с OSRM я также получаю OSM node_ids этих местоположений.

Теперь я хочу получить все имеющиеся у меня знаки остановки и светофоры на этом пути. Кроме того, было бы неплохо использовать тег max_speed OSM.

А пока у меня есть список nodesсо всеми node_id, которые я получил от OSRM, которые я передаю в Overpass (overpy) следующим образом (небольшой отрывок трека / узлов):

      import overpy
api = overpy.Overpass()

nodes = [4395513964, 1006458940, 4395513968, 74195178, 252285485, 27299730, 1965668925]

q_string = "[out:json]; (node(id:4395513964,1006458940,4395513968,74195178,252285485,27299730,1965668925); <; ); out;"

result = api.query(query_str)

result.ways

Я получил 10 таких выводов:

      [<overpy.Way id=4469704 nodes=[261755935, 261755936, 261755937, 1380714175, 82658976, 261755939, 82658975, 1380714202, 1380714262, 1380714246, 261756526, 1380714333, 261756547, 1380714293, 4428238953, 1380714171, 261756538, 1380714208, 261756536, 4428238913, 4428238956, 4428238985, 4428238977, 4428238962, 4428238916, 4428239393, 252285485, 27299730, 1965668925, 276105787, 276105785, 1965668928, 27299735, 2579884910, 384909488, 256853874, 401315477, 6311080568, 401315476, 6311080559, 6311080545, 401315475, 401315470, 401315463, 401315462, 401315461, 401315460, 401315459, 6311080543, 401315457, 1418193768, 27299743, 82658982, 82658981, 1331086552, 261755934, 261755935]>,
 <overpy.Way id=5208724 nodes=[27299725, 35208368, 4395513964, 1006458940]>,
 <overpy.Way id=23265821 nodes=[74195178, 74195176]>,
 <overpy.Way id=29261149 nodes=[1514552612, 321790693, 1514552609, 321790695, 251787168, 1514552502, 4663410835, 1514552465, 321791085, 1885139505, 1885139525, 321791087, 321791088, 321791089, 321791090, 321791091, 321791092, 321793186, 1909678245, 1909678399, 1573798824, 1909678354, 1909678255, 1573798815, 1573798778, 321793187, 1909678357, 1909678322, 321793188, 1909678379, 1909678315, 1909678373, 1319918314, 1909678395, 321793189, 1909678232, 1909678277, 321793190, 321792834, 2169769137, 321792835, 8357422315, 321793192, 2007050001, 321793193, 321793194, 2007099031, 2007099047, 2007099025, 2007099033, 321793195, 2007099094, 2007099023, 2007099075, 2007099088, 2007099064, 2007099037, 2007099119, 2007099073, 2096441917, 2096441915, 321793197, 8672322017, 8672288116, 321793198, 321793199, 8203474805, 8203474803, 321793200, 321793201, 321793202, 8203474794, 8203513923, 321793205, 321793206, 321793207, 321793528, 321793990, 321793991, 4368234952, 4975522960, 252285485, 27299730, 1965668925, 276105787, 276105785, 1965668928, 27299735, 2579884910, 384909488, 256853874, 401315477, 6311080568, 401315476, 6311080559, 6311080545, 401315475, 401315470, 401315463, 401315461, 401315460, 401315459, 6311080543, 6311080538, 1514552637, 1514552631, 321790691, 1514485305, 76597613, 1514485295, 1514485289, 1514485283, 1514485282, 251787103, 321790692, 1514552646]>,
 <overpy.Way id=29375200 nodes=[256207576, 2282603330, 256207577, 4054297285, 256207578, 256207580, 256207581, 4054297283, 256207582, 256207583, 322782340, 256207584, 256207585, 256207586, 256207587, 256207588, 256207590, 256207591, 256207592, 256207593, 256207594, 256207595, 256207596, 256207895, 1380745682, 4395513974, 1380745679, 1380745675, 1380745690, 4395513973, 252284576, 1380714265, 1380745695, 1380745678, 1380745681, 1380745687, 252284577, 252284578, 252284579, 252284580, 252285485, 252285486, 252284581, 3178786418, 654245173, 252284582, 252284583, 252284584, 1575156370, 252284585, 1575155933, 252284586, 1575155956, 252284587, 3178786416, 252284588, 252284589, 1575155948, 252284590, 252284591, 252285487, 252284592, 252284593, 252284594, 654245206, 5030439492, 569718577, 569718721, 569718790, 569718814]>,
 <overpy.Way id=86580217 nodes=[1006458962, 4395513960, 1006458901, 4975523007, 1006458940]>,
 <overpy.Way id=185880949 nodes=[27299730, 1965668925, 276105787, 276105785, 1965668928]>,
 <overpy.Way id=254835095 nodes=[1006458940, 4395513968, 74195178]>,
 <overpy.Way id=441856854 nodes=[74195178, 252285485, 27299730]>,
 <overpy.Way id=673906436 nodes=[401315477, 6311080570, 6311080571, 6311080572, 6311080573, 6311080574, 6311080575, 6311080576, 6311080577, 6311080578, 6311080579, 6311080580, 6311080581, 6311080582, 6311080583, 6311080584, 6311082385, 6311082386, 6311082387, 6311082388, 6311082389, 6311082390, 6311082391, 6311082392, 6311082393, 6311082394, 6311082395, 74195173, 2399394286, 1006458938, 74195174, 1006458918, 252285485, 27299730, 1965668925, 276105787, 276105785, 1965668928, 27299735, 2579884910, 384909488, 256853874, 401315477]>]

Теоретически теперь я могу освоить способы с .tagи найдите max_speed.
Однако узел 1006458940, например, является частью путей 5208724, 86580217 и 254835095, что затрудняет получение правильного.
Как лучше всего достичь моей цели - иметь GPS-трек с точками широты и долготы и возможными max_speeds, знаками остановки или светофорами?

Спасибо за любую помощь.

0 ответов

Другие вопросы по тегам