- Requête HTTP
- Paramètres de chemin d'accès
- Corps de la requête
- Corps de la réponse
- Niveaux d'accès des autorisations
- Autorisations IAM
Envoie un OptimizeToursRequest contenant un ShipmentModel et renvoie un OptimizeToursResponse contenant des ShipmentRoute, qui sont un ensemble d'itinéraires à effectuer par les véhicules en minimisant le coût global.
Un modèle ShipmentModel se compose principalement de Shipment à effectuer et de Vehicle pouvant être utilisées pour transporter les Shipment. Les ShipmentRoute attribuent des Shipment aux Vehicle. Plus précisément, ils attribuent une série de Visit à chaque véhicule, où un Visit correspond à un VisitRequest, qui est un retrait ou une livraison pour un Shipment.
L'objectif est d'attribuer des ShipmentRoute à des Vehicle de manière à minimiser le coût total, qui comporte de nombreux composants définis dans ShipmentModel.
Requête HTTP
POST https://routeoptimization.googleapis.com/v1/{parent=projects/*/locations/*}:optimizeTours
L'URL utilise la syntaxe de transcodage gRPC.
Paramètres de chemin d'accès
| Paramètres | |
|---|---|
parent |
Obligatoire. Projet ou emplacement cibles pour passer un appel. Format :
Si aucun emplacement n'est spécifié, une région est automatiquement sélectionnée. |
Corps de la requête
Le corps de la requête contient des données présentant la structure suivante :
| Représentation JSON |
|---|
{ "timeout": string, "model": { object ( |
| Champs | |
|---|---|
timeout |
Si ce délai avant expiration est défini, le serveur renvoie une réponse avant l'expiration du délai ou l'échéance du serveur pour les requêtes synchrones, selon la première échéance atteinte. Pour les requêtes asynchrones, le serveur génère une solution (si possible) avant l'expiration du délai. Durée en secondes avec neuf chiffres au maximum après la virgule et se terminant par " |
model |
Modèle d'expédition à résoudre. |
solvingMode |
Par défaut, le mode de résolution est |
searchMode |
Mode Recherche utilisé pour répondre à la requête. |
injectedFirstSolutionRoutes[] |
Guidez l'algorithme d'optimisation pour qu'il trouve une première solution semblable à une solution précédente. Le modèle est contraint lorsque la première solution est créée. Les livraisons non effectuées sur un itinéraire sont implicitement ignorées dans la première solution, mais elles peuvent être effectuées dans les solutions suivantes. La solution doit répondre à certaines hypothèses de validité de base :
Si la solution injectée n'est pas réalisable, une erreur de validation n'est pas nécessairement renvoyée. Une erreur indiquant l'irréalisabilité peut être renvoyée à la place. |
injectedSolutionConstraint |
Limitez l'algorithme d'optimisation pour trouver une solution finale semblable à une solution précédente. Par exemple, cela peut être utilisé pour figer des portions d'itinéraires déjà effectuées ou à effectuer, mais qui ne doivent pas être modifiées. Si la solution injectée n'est pas réalisable, une erreur de validation n'est pas nécessairement renvoyée. Une erreur indiquant l'irréalisabilité peut être renvoyée à la place. |
refreshDetailsRoutes[] |
Si elle n'est pas vide, les itinéraires indiqués seront actualisés, sans que leur séquence de visites ou leurs temps de trajet sous-jacents soient modifiés. Seuls les autres détails seront mis à jour. Cela ne résout pas le modèle. Depuis le 11/2020, cela ne remplit que les polylignes des itinéraires non vides et nécessite que Les champs Ce champ ne doit pas être utilisé avec
|
interpretInjectedSolutionsUsingLabels |
Si la réponse est "True" :
Cette interprétation s'applique aux champs Si la valeur est "true", les libellés des catégories suivantes ne doivent apparaître qu'une seule fois dans leur catégorie :
Si un La suppression de visites ou d'itinéraires entiers d'une solution injectée peut avoir une incidence sur les contraintes implicites, ce qui peut entraîner une modification de la solution, des erreurs de validation ou une infaisabilité. REMARQUE : L'appelant doit s'assurer que chaque |
considerRoadTraffic |
Tenez compte de l'estimation du trafic pour calculer les champs |
populatePolylines |
Si la valeur est "true", les polylignes seront renseignées dans les |
populateTransitionPolylines |
Si la valeur est "true", les polylignes et les jetons de route seront renseignés dans la réponse |
allowLargeDeadlineDespiteInterruptionRisk |
Si cette valeur est définie, la requête peut avoir un délai (voir https://grpc.io/blog/deadlines) allant jusqu'à 60 minutes. Sinon, le délai maximal est de 30 minutes. Notez que les requêtes de longue durée présentent un risque d'interruption beaucoup plus élevé (mais toujours faible). |
useGeodesicDistances |
Si la valeur est "true", les distances de trajet seront calculées à l'aide de distances géodésiques au lieu de distances Google Maps, et les temps de trajet seront calculés à l'aide de distances géodésiques avec une vitesse définie par |
label |
Libellé pouvant être utilisé pour identifier cette requête, renvoyé dans |
geodesicMetersPerSecond |
Lorsque |
maxValidationErrors |
Tronque le nombre d'erreurs de validation renvoyées. Ces erreurs sont généralement associées à une charge utile d'erreur INVALID_ARGUMENT en tant qu'information détaillée sur l'erreur BadRequest (https://cloud.google.com/apis/design/errors#error_details), sauf si solvingMode=VALIDATE_ONLY : consultez le champ |
Corps de la réponse
Si la requête aboutit, le corps de la réponse contient une instance de OptimizeToursResponse.
Champs d'application des autorisations
Requiert le niveau d'accès OAuth suivant :
https://www.googleapis.com/auth/cloud-platform
Autorisations IAM
Nécessite l'autorisation IAM suivante sur la ressource parent :
routeoptimization.locations.use
Pour en savoir plus, consultez la documentation IAM.