Оптимизация промежуточных точек — это функция Routes Preferred, расширяющая функциональность ComputeRoutes . Она оптимизирует порядок промежуточных точек на маршруте путешественника, обеспечивая максимально эффективное прохождение маршрута. Реализация оптимизации промежуточных точек ComputeRoutes поддерживает следующие режимы передвижения:
- Вождение
- Моторизованный двухколесный транспорт
- Велоспорт
- Ходьба
Зачем нужна оптимизация по точкам маршрута?
При разработке приложения, которое направляет пользователей через ряд контрольных точек на пути к месту назначения, важно, чтобы путешественник проходил эти точки в оптимальном порядке. Это гарантирует, что путешественник достигнет каждой контрольной точки за кратчайшее время.
Как это работает
По умолчанию ComputeRoutes вычисляет маршрут через свои путевые точки в том порядке, в котором они были первоначально предоставлены. Вы можете заставить ComputeRoutes оптимизировать маршрут, переставив промежуточные путевые точки в более эффективном порядке. Вы получите маршрут с оптимизированными путевыми точками, если установите поле optimizeWaypointOrder в теле запроса в значение true .
Примечание : Расчет оптимизации маршрута по точкам маршрута в основном основан на времени в пути, но эта функция также учитывает другие факторы, такие как расстояние и количество поворотов.
Получить переупорядоченные путевые точки
Чтобы получить маршрут с переупорядоченными путевыми точками, установите логическое поле optimizeWaypointOrder в значение true в теле запроса к ComputeRoutes . Также включите поле optimizedIntermediateWaypointIndex в маску полей. Тело ответа содержит оптимизированный порядок путевых точек в полях optimizedIntermediateWaypointIndex .
Примечание : Поле optimizedIntermediateWaypointIndex возвращает значения, отсчитываемые от нуля.
Пример запроса
В приведенном ниже примере запроса указан маршрут вблизи кампуса Стэнфордского университета. Точки маршрута указаны последовательно в запросе. Запрос содержит начальную и конечную точки, а также две промежуточные точки.
POST /v1alpha:computeRoutes
Host: routespreferred.googleapis.com
Content-Type: application/json
X-Server-Timeout: 10
X-Goog-Api-Key: YOUR_API_KEY
X-Goog-FieldMask: routes.optimizedIntermediateWaypointIndex,routes.duration,routes.distanceMeters,routes.polyline.encodedPolyline
{
"origin":{
"location":{
"latLng":{
"latitude": 37.418956,
"longitude": -122.160815
}
}
},
"intermediates": [
{
"location":{
"latLng":{
"latitude": 37.4176423,
"longitude":-122.1102246
}
}
},
{
"location":{
"latLng":{
"latitude": 37.407689,
"longitude": -122.1360597
}
}
}
],
"destination":{
"location":{
"latLng":{
"latitude": 37.4032137,
"longitude": -122.0349119
}
}
},
"travelMode": "DRIVE",
"optimizeWaypointOrder": true,
"routingPreference": "TRAFFIC_AWARE"}
Пример ответа
Переупорядоченные индексы промежуточных путевых точек можно найти в полях optimizedIntermediateWaypointIndex объекта routes в теле ответа. Закодированная полилиния такая же, как в Directions API и ComputeRoutes .
routes {
distance_meters: 17647
duration {
seconds: 1866
}
polyline {
encoded_polyline: "wkkcFvorhVU{@Ec@C}CG}@Mm@[}@i@y@[[g@_@Tk@BSjCgGfF|D\\Pv@Lj@@XaCTeC\\aCTs@`ByD`@k@h@e@x@Yh@GtADhBF|@G`AWpAs@lAsAdA{A`BmDr@cBmUqQoS}OyGmFiBsAgEwD}CaCU_@Og@@e@Hy@nGkO~@sBr@cBlDqIlByEp@}AjIfGnBbBHLLd@^p@~ErDfNrKrA~@DIhEeBTQ~AqDlE{KjBgE|FnEh@aAi@`A}FoE~AmD`A}BcAm@mHwFwD}CkLwIsDqCgF_EG[GKnCsDrA_BrC_CnCoBpEkD`EyClCsBcBeBIAkGkH]k@eJmKQKsAuA_@g@wCoDGQmEmFmIqROKaDuHvBkBxAgANCRH^f@v@dBHDD?`AUiBqEhBpEaATMCQYm@wAY]SIOByAfAwBjB_ByDaAwBiCeIA[c@aBqEuNOm@IQbA{c@p@aZFmCTuBLg@Tc@BUAKxOeV~Vy_@nBoDv@_BvAcDzA_EdG{RdC{HtIsY|B{Hx@mDbAuFdBsMbKsv@TaBf@}AdF{Sn@_DJq@Lo@aE`@]GUQmAmAQk@@g@RK`Ce@d@UDEPc@f@cCrAyGJs@X{AbIem@bA{JD_AIaAMg@o@{A_Ad@y@NaCLCsCK_FGI"
}
optimizedIntermediateWaypointIndex: 1
optimizedIntermediateWaypointIndex: 0
}
В этом примере обратите внимание, что оптимизация путевых точек меняет их исходный порядок на обратный.
Рекомендуемые методы
Запрос с оптимизированными путевыми точками обрабатывается дольше, чем простой запрос маршрутизации. Поэтому мы рекомендуем установить более длительный таймаут при вызове метода, задав значение заголовка запроса X-Server-Timeout не менее десяти секунд. Если ошибки таймаута продолжают возникать, можно добавить еще одну секунду и повторить попытку.
Ограничения использования
Для использования оптимизации по точкам маршрута необходимо соблюдать следующие ограничения и условия использования:
Вы можете указать лимит использования промежуточных точек на вашем маршруте:
- До 98 путевых точек с использованием только координат широты и долготы.
- До 25 путевых точек, если вы укажете какие-либо из них с помощью идентификаторов мест.
Все ваши путевые точки должны быть типа «остановка» . Ни одна из ваших путевых точек не может быть типа «через» .
Необходимо добавить
routes.optimizedIntermediateWaypointIndexв маску поля.Если ваш запрос содержит 25 или более промежуточных точек, он также должен соответствовать следующим условиям:
Суммарное расстояние по прямой между всеми путевыми точками должно быть менее 1000 км. Это расстояние включает в себя как начальную, так и конечную точки маршрута.
Режим движения должен быть установлен в положение DRIVE (Вождение).