交通模型使用特定算法和因素来预测交通状况对给定路线的总行程时间有何影响。Routes API 提供不同的交通模型类型,以便确定计算交通时长时要优先考虑的不同因素。您可以在计算路线或路线矩阵的用时时,指定路线应使用的交通模型类型。设置流量模型类型后,duration
字段中返回的值会因您选择的流量模型而异。
Routes API Compute Routes
和 Compute Route Matrix
方法都支持交通模型类型。
默认情况下,这两种方法都使用 BEST_GUESS
流量模型类型。
指定流量类型
设置出发地和目的地。
如果您的出发时间是未来时间,请使用
departure_time
参数添加时间。如果您未指定出发时间,则默认为当前时间。选择要与
trafficModel
参数搭配使用的流量模型以及以下类型之一:BEST_GUESS
(默认)- 表示返回的duration_in_traffic
应该是最准确的行程时间估算值(根据已知的历史路况信息和实时路况信息得出)。departure_time
越接近当前时间,实时路况信息就越重要。使用默认类型BEST_GUESS
可为大多数用例提供最有用的预测。PESSIMISTIC
,以请求返回的duration_in_traffic
根据交通状况较差的日子的历史交通状况对时间进行建模。此类型的估算时长在大多数日子里都可能长于实际行程时间。但在偶尔路况特别糟糕的时候,实际行程时间仍可能会超过此估算值。OPTIMISTIC
,以请求返回的duration_in_traffic
根据交通状况良好的日子的历史交通状况对时间进行建模。此类型的预计时长在大多数日子里都可能短于实际行程时间。但在交通状况特别理想的少数日子里,实际行程时间可能仍会比此估算值短。
例如:
"trafficModel": "OPTIMISTIC"
。在字段掩码中指定
routes.duration
字段。REST
-H X-Goog-FieldMask: routes.duration
RPC
const (fieldMask = "routes.duration")
Routes API 估算交通时间时,会使用您请求的交通模型类型。
示例:交通模型请求
例如,此请求指定使用特定出发时间的 OPTIMISTIC
交通模型类型来估算时长:
curl -X POST -H 'content-type: application/json' -d ' { "origin": { "address": "Kyoto, Japan" }, "destination": { "placeId": "ChIJrYtcv-urAWAR3XzWvXv8n_s" }, "travelMode": "DRIVE", "routingPreference": "TRAFFIC_AWARE_OPTIMAL", "trafficModel": "OPTIMISTIC" }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.duration' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
此请求会使用行程的 OPTIMISTIC
交通模型类型返回预计时长:
"duration": "1238s"
如果您将交通模型类型更改为 PESSIMISTIC
,则返回的时长会更长:
"duration": "2436s"