交通模型使用特定算法和因素来预测交通状况对给定路线的总行程时间有何影响。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"