- Richiesta HTTP
- Parametri del percorso
- Corpo della richiesta
- Corpo della risposta
- Ambiti di autorizzazione
- Autorizzazioni IAM
Invia un OptimizeToursRequest
contenente un ShipmentModel
e restituisce un OptimizeToursResponse
contenente ShipmentRoute
, ovvero un insieme di percorsi da eseguire dai veicoli per ridurre al minimo il costo complessivo.
Un modello ShipmentModel
è costituito principalmente da Shipment
da eseguire e da Vehicle
che possono essere utilizzati per trasportare i Shipment
. I ShipmentRoute
assegnano i Shipment
ai Vehicle
. Nello specifico, assegnano una serie di Visit
a ogni veicolo, dove un Visit
corrisponde a un VisitRequest
, ovvero un ritiro o una consegna per un Shipment
.
L'obiettivo è fornire un'assegnazione di ShipmentRoute
a Vehicle
che minimizza il costo totale, dove il costo ha molti componenti definiti in ShipmentModel
.
Richiesta HTTP
POST https://routeoptimization.googleapis.com/v1/{parent=projects/*}:optimizeTours
L'URL utilizza la sintassi di transcodifica gRPC.
Parametri del percorso
Parametri | |
---|---|
parent |
Obbligatorio. Progetto o località di destinazione per effettuare una chiamata. Formato: * Se non viene specificata alcuna località, verrà scelta automaticamente una regione. |
Corpo della richiesta
Il corpo della richiesta contiene dati con la seguente struttura:
Rappresentazione JSON |
---|
{ "timeout": string, "model": { object ( |
Campi | |
---|---|
timeout |
Se questo timeout è impostato, il server restituisce una risposta prima che sia trascorso il periodo di timeout o che venga raggiunta la scadenza del server per le richieste sincrone, a seconda del caso. Per le richieste asincrone, il server genererà una soluzione (se possibile) prima del timeout. Una durata in secondi con un massimo di nove cifre frazionarie, che termina con " |
model |
Modello di spedizione da risolvere. |
solving |
Per impostazione predefinita, la modalità di risoluzione è |
search |
Modalità di ricerca utilizzata per risolvere la richiesta. |
injected |
Guida l'algoritmo di ottimizzazione a trovare una prima soluzione simile a una precedente. Il modello è vincolato quando viene creata la prima soluzione. Eventuali spedizioni non eseguite su un percorso vengono ignorate implicitamente nella prima soluzione, ma possono essere eseguite nelle soluzioni successive. La soluzione deve soddisfare alcune ipotesi di validità di base:
Se la soluzione iniettata non è fattibile, non viene necessariamente restituito un errore di convalida, ma potrebbe essere restituito un errore che indica l'impossibilità di applicazione. |
injected |
Limita l'algoritmo di ottimizzazione per trovare una soluzione finale simile a una precedente. Ad esempio, può essere utilizzato per bloccare parti di percorsi già completati o da completare, ma che non devono essere modificati. Se la soluzione iniettata non è fattibile, non viene necessariamente restituito un errore di convalida, ma potrebbe essere restituito un errore che indica l'impossibilità di applicazione. |
refresh |
Se non è vuoto, i percorsi specificati verranno aggiornati, senza modificare la sequenza di visite o i tempi di percorrenza sottostanti: verranno aggiornati solo gli altri dettagli. Questo non risolve il problema del modello. A partire da novembre 2020, vengono compilati solo i polilinei dei percorsi non vuoti e I campi Questo campo non deve essere utilizzato insieme a
|
interpret |
Se true:
Questa interpretazione si applica ai campi Se true, le etichette nelle seguenti categorie devono apparire al massimo una volta nella rispettiva categoria:
Se un La rimozione di visite ai percorsi o di interi percorsi da una soluzione iniettata può influire sui vincoli impliciti, il che può comportare la modifica della soluzione, errori di convalida o l'impossibilità di applicazione. NOTA: l'utente che chiama deve assicurarsi che ogni |
consider |
Tieni conto della stima del traffico per calcolare i campi |
populate |
Se true, i polilinee verranno compilati nelle |
populate |
Se true, i polilinee e i token di percorso verranno compilati nella risposta |
allow |
Se questo valore è impostato, la richiesta può avere una scadenza (vedi https://grpc.io/blog/deadlines) fino a 60 minuti. In caso contrario, la scadenza massima è di soli 30 minuti. Tieni presente che le richieste a lungo termine presentano un rischio di interruzione notevolmente maggiore (ma comunque ridotto). |
use |
Se true, le distanze di viaggio verranno calcolate utilizzando le distanze geodetiche anziché quelle di Google Maps e i tempi di viaggio verranno calcolati utilizzando le distanze geodetiche con una velocità definita da |
label |
L'etichetta che può essere utilizzata per identificare questa richiesta, riportata in |
geodesic |
Quando |
max |
Tronca il numero di errori di convalida restituiti. Questi errori sono in genere associati al payload dell'errore INVALID_ARGUMENT come dettaglio dell'errore BadRequest (https://cloud.google.com/apis/design/errors#error_details), a meno che solvingMode=VALIDATE_ONLY: consulta il campo |
Corpo della risposta
In caso di esito positivo, il corpo della risposta contiene un'istanza di OptimizeToursResponse
.
Ambiti di autorizzazione
Richiede il seguente ambito OAuth:
https://www.googleapis.com/auth/cloud-platform
Autorizzazioni IAM
Richiede la seguente autorizzazione IAM sulla risorsa parent
:
routeoptimization.locations.use
Per ulteriori informazioni, consulta la documentazione di IAM.