Index
RouteOptimization(Benutzeroberfläche)AggregatedMetrics(Meldung)BatchOptimizeToursMetadata(Meldung)BatchOptimizeToursRequest(Meldung)BatchOptimizeToursRequest.AsyncModelConfig(Meldung)BatchOptimizeToursResponse(Meldung)BreakRule(Meldung)BreakRule.BreakRequest(Meldung)BreakRule.FrequencyConstraint(Meldung)DataFormat(Aufzählung)DistanceLimit(Meldung)GcsDestination(Meldung)GcsSource(Meldung)InjectedSolutionConstraint(Meldung)InjectedSolutionConstraint.ConstraintRelaxation(Meldung)InjectedSolutionConstraint.ConstraintRelaxation.Relaxation(Meldung)InjectedSolutionConstraint.ConstraintRelaxation.Relaxation.Level(Aufzählung)InputConfig(Meldung)Location(Meldung)OptimizeToursLongRunningMetadata(Meldung)OptimizeToursRequest(Meldung)OptimizeToursRequest.SearchMode(Option)OptimizeToursRequest.SolvingMode(Option)OptimizeToursResponse(Meldung)OptimizeToursResponse.Metrics(Meldung)OptimizeToursUriMetadata(Meldung)OptimizeToursUriRequest(Meldung)OptimizeToursUriResponse(Meldung)OptimizeToursValidationError(Meldung)OptimizeToursValidationError.FieldReference(Meldung)OutputConfig(Meldung)RouteModifiers(Meldung)Shipment(Meldung)Shipment.Load(Meldung)Shipment.VisitRequest(Meldung)ShipmentModel(Meldung)ShipmentModel.DurationDistanceMatrix(Meldung)ShipmentModel.DurationDistanceMatrix.Row(Meldung)ShipmentModel.Objective(Meldung)ShipmentModel.Objective.Type(Aufzählung)ShipmentModel.PrecedenceRule(Meldung)ShipmentRoute(Meldung)ShipmentRoute.Break(Meldung)ShipmentRoute.EncodedPolyline(Meldung)ShipmentRoute.Transition(Meldung)ShipmentRoute.VehicleLoad(Meldung)ShipmentRoute.Visit(Meldung)ShipmentTypeIncompatibility(Meldung)ShipmentTypeIncompatibility.IncompatibilityMode(Aufzählung)ShipmentTypeRequirement(Meldung)ShipmentTypeRequirement.RequirementMode(Aufzählung)SkippedShipment(Meldung)SkippedShipment.Reason(Meldung)SkippedShipment.Reason.Code(Aufzählung)TimeWindow(Meldung)TransitionAttributes(Meldung)Uri(Meldung)Vehicle(Meldung)Vehicle.DurationLimit(Meldung)Vehicle.LoadLimit(Meldung)Vehicle.LoadLimit.Interval(Meldung)Vehicle.LoadLimit.LoadCost(Meldung)Vehicle.TravelMode(Option)Vehicle.UnloadingPolicy(Option)VehicleFullness(Meldung)Waypoint(Meldung)
RouteOptimization
Ein Dienst zur Optimierung von Fahrzeugrouten.
Gültigkeit bestimmter Feldtypen:
google.protobuf.Timestamp- Die Zeiten sind in Unix-Zeit angegeben: Sekunden seit 1970-01-01T00:00:00+00:00.
- „seconds“ muss im Bereich [0, 253402300799] liegen, d.h. im Bereich [1970-01-01T00:00:00+00:00, 9999-12-31T23:59:59+00:00].
- „nanos“ muss nicht festgelegt oder auf 0 gesetzt sein.
google.protobuf.Duration- „seconds“ muss im Bereich [0, 253402300799] liegen, d.h. im Bereich [1970-01-01T00:00:00+00:00, 9999-12-31T23:59:59+00:00].
- „nanos“ muss nicht festgelegt oder auf 0 gesetzt sein.
google.type.LatLng- Der Breitengrad muss im Bereich [-90,0, 90,0] liegen.
- Der Längengrad muss im Bereich [-180,0, 180,0] liegen.
- Mindestens einer der Werte für Breiten- und Längengrad muss ungleich null sein.
| BatchOptimizeTours |
|---|
|
Optimiert Fahrzeugrouten für eine oder mehrere Diese Methode ist ein Vorgang mit langer Ausführungszeit. Die Eingaben für die Optimierung ( Der Nutzer kann Wenn das Feld Wenn das Feld
|
| OptimizeTours |
|---|
|
Sendet eine Ein Ziel ist es,
|
| OptimizeToursLongRunning |
|---|
|
Dies ist eine Variante der Der zurückgegebene Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/otlr/make-request.
|
| OptimizeToursUri |
|---|
|
Dies ist eine Variante der Der Client gibt den URI des in Google Cloud Storage gespeicherten Diese Methode sollte für Optimierungen, die länger als ein paar Minuten dauern, und für Ein-/Ausgabegrößen, die größer als 8 MB sind, der Der zurückgegebene Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/otlr/make-request.
|
AggregatedMetrics
Zusammengefasste Messwerte für ShipmentRoute (bzw. für OptimizeToursResponse für alle Transition- und/oder Visit-Elemente (bzw. für alle ShipmentRoute-Elemente).
| Felder | |
|---|---|
performed_shipment_count |
Anzahl der durchgeführten Sendungen. Ein Abhol- und Lieferpaar wird nur einmal gezählt. |
travel_duration |
Die gesamte Reisedauer für eine Route oder Lösung. |
wait_duration |
Die gesamte Wartezeit für eine Route oder eine Lösung. |
delay_duration |
Die Gesamtdauer der Verzögerung für eine Route oder Lösung. |
break_duration |
Die Gesamtunterbrechungsdauer für eine Route oder Lösung. |
visit_duration |
Die Gesamtdauer eines Besuchs für eine Route oder eine Lösung. |
total_duration |
Die Gesamtdauer sollte der Summe aller oben genannten Zeiträume entsprechen. Bei Routen entspricht es außerdem: |
travel_distance_meters |
Die gesamte zurückzulegende Strecke für eine Route oder Lösung. |
max_loads |
Die maximale Belastung, die auf der gesamten Route (bzw. Lösung) erreicht wird, für jede der Mengen auf dieser Route (bzw. Lösung), berechnet als das Maximum über alle |
performed_mandatory_shipment_count |
Anzahl der durchgeführten Pflichtsendungen. Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
performed_shipment_penalty_cost_sum |
Die Summe der Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
BatchOptimizeToursMetadata
Dieser Typ hat keine Felder.
Vorgangsmetadaten für BatchOptimizeToursRequest-Aufrufe.
BatchOptimizeToursRequest
Anfrage zum Batch-Optimieren von Touren als asynchronen Vorgang. Jede Eingabedatei sollte ein OptimizeToursRequest enthalten und jede Ausgabedatei ein OptimizeToursResponse. Die Anfrage enthält Informationen zum Lesen/Schreiben und Parsen der Dateien. Alle Ein- und Ausgabedateien sollten sich im selben Projekt befinden.
| Felder | |
|---|---|
parent |
Erforderlich. Zielprojekt und Standort zum Anrufen festlegen. Format:
Wenn kein Ort angegeben ist, wird automatisch eine Region ausgewählt. |
model_configs[] |
Erforderlich. Informationen zu Ein- und Ausgabe für jedes Kaufmodell, z. B. Dateipfade und Datenformate. |
AsyncModelConfig
Informationen zum asynchronen Lösen eines Optimierungsmodells.
| Felder | |
|---|---|
display_name |
Optional. Benutzerdefinierter Modellname, der von Nutzern als Alias verwendet werden kann, um Modelle im Blick zu behalten. |
input_config |
Erforderlich. Informationen zum Eingabemodell. |
output_config |
Erforderlich. Die gewünschten Standortinformationen für die Ausgabe. |
BatchOptimizeToursResponse
Dieser Typ hat keine Felder.
Antwort auf eine BatchOptimizeToursRequest. Dieser Wert wird im Vorgang mit langer Ausführungszeit zurückgegeben, nachdem der Vorgang abgeschlossen ist.
BreakRule
Regeln zum Generieren von Zeitunterbrechungen für ein Fahrzeug (z.B. Mittagspausen). Eine Pause ist ein zusammenhängender Zeitraum, in dem das Fahrzeug an seiner aktuellen Position inaktiv bleibt und keinen Besuch durchführen kann. Eine Unterbrechung kann folgende Ursachen haben:
- während der Reise zwischen zwei Besuchen (einschließlich der Zeit unmittelbar vor oder nach einem Besuch, aber nicht in der Mitte eines Besuchs). In diesem Fall wird die entsprechende Transitzeit zwischen den Besuchen verlängert.
- oder vor dem Start des Fahrzeugs (das Fahrzeug darf nicht mitten in einer Pause starten). In diesem Fall wird die Startzeit des Fahrzeugs nicht beeinflusst.
- oder nach dem Ende der Fahrt (siehe oben, mit der Endzeit der Fahrt).
| Felder | |
|---|---|
break_requests[] |
Reihenfolge der Unterbrechungen. Sehen Sie sich die Meldung |
frequency_constraints[] |
Es können mehrere |
BreakRequest
Die Reihenfolge der Pausen (d.h. ihre Anzahl und Reihenfolge), die für jedes Fahrzeug gelten, muss im Voraus bekannt sein. Die wiederholten BreakRequests definieren diese Sequenz in der Reihenfolge, in der sie auftreten müssen. Die Zeiträume (earliest_start_time / latest_start_time) können sich überschneiden, müssen aber mit der Reihenfolge kompatibel sein (das wird geprüft).
| Felder | |
|---|---|
earliest_start_time |
Erforderlich. Inklusive Untergrenze für den Beginn der Pause. |
latest_start_time |
Erforderlich. Obergrenze (einschließlich) für den Beginn der Pause. |
min_duration |
Erforderlich. Mindestdauer der Pause. Muss positiv sein. |
FrequencyConstraint
Die oben angegebene Häufigkeit und Dauer der Pausen kann weiter eingeschränkt werden, indem eine Mindestpausenhäufigkeit festgelegt wird, z. B. „Alle 12 Stunden muss eine Pause von mindestens einer Stunde eingelegt werden“. Wenn wir davon ausgehen, dass dies als „In einem beliebigen gleitenden Zeitfenster von 12 Stunden muss es mindestens eine Pause von mindestens einer Stunde geben“ interpretiert werden kann, würde das Beispiel in die folgende FrequencyConstraint übersetzt:
{
min_break_duration { seconds: 3600 } # 1 hour.
max_inter_break_duration { seconds: 39600 } # 11 hours (12 - 1 = 11).
}
Das Timing und die Dauer der Pausen in der Lösung berücksichtigen alle diese Einschränkungen sowie die bereits in der BreakRequest angegebenen Zeitfenster und Mindestdauern.
Eine FrequencyConstraint kann in der Praxis auch auf nicht aufeinanderfolgende Pausen angewendet werden. Im folgenden Zeitplan wird beispielsweise das Beispiel „1 Stunde alle 12 Stunden“ berücksichtigt:
04:00 vehicle start
.. performing travel and visits ..
09:00 1 hour break
10:00 end of the break
.. performing travel and visits ..
12:00 20-min lunch break
12:20 end of the break
.. performing travel and visits ..
21:00 1 hour break
22:00 end of the break
.. performing travel and visits ..
23:59 vehicle end
| Felder | |
|---|---|
min_break_duration |
Erforderlich. Mindestdauer der Pause für diese Einschränkung. Nicht negativ. Siehe Beschreibung von |
max_inter_break_duration |
Erforderlich. Die maximal zulässige Dauer eines beliebigen Zeitintervalls auf der Route, das nicht mindestens teilweise eine Pause von |
DataFormat
Datenformate für Ein- und Ausgabedateien.
| Enums | |
|---|---|
DATA_FORMAT_UNSPECIFIED |
Ungültiger Wert. Das Format darf nicht UNSPECIFIED sein. |
JSON |
JavaScript Object Notation. |
PROTO_TEXT |
Textformat für Protokollpuffer. Weitere Informationen finden Sie unter https://protobuf.dev/reference/protobuf/textformat-spec/. |
DistanceLimit
Ein Limit, das die maximale Entfernung definiert, die zurückgelegt werden kann. Sie kann entweder hart oder weich sein.
Wenn ein Soft Limit definiert ist, müssen sowohl soft_max_meters als auch cost_per_kilometer_above_soft_max definiert und nicht negativ sein.
| Felder | |
|---|---|
max_meters |
Eine harte Beschränkung, die den Abstand auf maximal „max_meters“ begrenzt. Das Limit darf nicht negativ sein. |
soft_max_meters |
Ein weiches Limit erzwingt keine maximale Entfernung, führt aber bei Überschreitung zu Kosten, die zu anderen im Modell definierten Kosten mit derselben Einheit addiert werden. Wenn „soft_max_meters“ definiert ist, muss der Wert kleiner als „max_meters“ und nicht negativ sein. |
cost_per_kilometer_below_soft_max |
Anfallende Kosten pro Kilometer, die bis zu Diese Kosten werden in |
cost_per_kilometer_above_soft_max |
Kosten pro Kilometer, die anfallen, wenn die Entfernung das Limit von Die Kosten dürfen nicht negativ sein. |
GcsDestination
Der Google Cloud Storage-Speicherort, in den die Ausgabedatei(en) geschrieben werden.
| Felder | |
|---|---|
uri |
Erforderlich. Google Cloud Storage-URI. |
GcsSource
Der Google Cloud Storage-Speicherort, aus dem die Eingabedatei gelesen wird.
| Felder | |
|---|---|
uri |
Erforderlich. URI eines Google Cloud Storage-Objekts im Format |
InjectedSolutionConstraint
Die Lösung wird in die Anfrage eingefügt. Sie enthält Informationen dazu, welche Besuche eingeschränkt werden müssen und wie.
| Felder | |
|---|---|
routes[] |
Routen der Lösung, die eingefügt werden soll. Einige Routen werden möglicherweise aus der ursprünglichen Lösung ausgelassen. Die Routen und übersprungenen Sendungen müssen die für |
skipped_shipments[] |
Übersprungene Sendungen der einzufügenden Lösung. Einige werden möglicherweise aus der ursprünglichen Lösung ausgelassen. Weitere Informationen finden Sie im Feld |
constraint_relaxations[] |
Gibt für null oder mehr Fahrzeuggruppen an, wann und wie stark Einschränkungen gelockert werden sollen. Wenn dieses Feld leer ist, sind alle nicht leeren Fahrzeugrouten vollständig eingeschränkt. |
ConstraintRelaxation
Gibt für eine Gruppe von Fahrzeugen an, bei welchem Schwellenwert bzw. welchen Schwellenwerten die Einschränkungen für Besuche gelockert werden und auf welche Stufe. Sendungen, die im Feld skipped_shipment aufgeführt sind, müssen übersprungen werden, d.h., sie können nicht ausgeführt werden.
| Felder | |
|---|---|
relaxations[] |
Alle Lockerungen der Besuchseinschränkungen, die für Besuche auf Routen mit Fahrzeugen in |
vehicle_indices[] |
Gibt die Fahrzeugindexe an, für die die Besuchsrestriktion Ein Fahrzeugindex wird genauso wie |
Entspannung
Wenn relaxations leer ist, sind die Startzeit und die Reihenfolge aller Besuche auf routes vollständig eingeschränkt und es dürfen keine neuen Besuche in diese Routen eingefügt oder hinzugefügt werden. Außerdem sind die Start- und Endzeit eines Fahrzeugs in routes vollständig eingeschränkt, es sei denn, das Fahrzeug ist leer (d.h., es hat keine Besuche und used_if_route_is_empty ist im Modell auf „false“ gesetzt).
relaxations(i).level gibt die Stufe der Einschränkungslockerung an, die auf einen Besuch #j angewendet wird, der die folgenden Bedingungen erfüllt:
route.visits(j).start_time >= relaxations(i).threshold_timeUNDj + 1 >= relaxations(i).threshold_visit_count
Analog dazu wird der Fahrzeugstart auf relaxations(i).level verschoben, wenn Folgendes gilt:
vehicle_start_time >= relaxations(i).threshold_timeUNDrelaxations(i).threshold_visit_count == 0und das Fahrzeugende wird aufrelaxations(i).levelgelockert, wenn Folgendes zutrifft:vehicle_end_time >= relaxations(i).threshold_timeUNDroute.visits_size() + 1 >= relaxations(i).threshold_visit_count
Wenn Sie eine Lockerungsstufe anwenden möchten, wenn ein Besuch die threshold_visit_count ODER die threshold_time erfüllt, fügen Sie zwei relaxations mit derselben level hinzu: eine mit nur threshold_visit_count und die andere mit nur threshold_time. Wenn ein Besuch die Bedingungen mehrerer relaxations erfüllt, wird die am wenigsten restriktive Ebene angewendet. Daher wird das Entspannungsniveau vom Fahrzeugstart über die Routenbesuche bis zum Fahrzeugende immer entspannter, d.h., es nimmt im Laufe der Route nicht ab.
Die Zeit und Reihenfolge der Routenbesuche, die die Schwellenwertbedingungen keiner relaxations erfüllen, sind vollständig eingeschränkt und es dürfen keine Besuche in diese Sequenzen eingefügt werden. Wenn der Start oder das Ende eines Fahrzeugs nicht den Bedingungen einer Lockerung entspricht, wird die Zeit festgelegt, sofern das Fahrzeug nicht leer ist.
| Felder | |
|---|---|
level |
Die Stufe der Einschränkungsaufhebung, die angewendet wird, wenn die Bedingungen am oder nach dem |
threshold_time |
Die Zeit, zu der oder nach der die Lockerung |
threshold_visit_count |
Die Anzahl der Besuche, nach denen die Lockerung Wenn es |
Level
Gibt die verschiedenen Stufen der Lockerung von Einschränkungen an, die für einen Besuch und die nachfolgenden Besuche angewendet werden, wenn die Schwellenwertbedingungen erfüllt sind.
Die Aufzählung unten erfolgt in der Reihenfolge der zunehmenden Lockerung.
| Enums | |
|---|---|
LEVEL_UNSPECIFIED |
Implizites Standard-Relaxierungsniveau: Es werden keine Einschränkungen gelockert, d.h., alle Besuche sind vollständig eingeschränkt. Dieser Wert darf in |
RELAX_VISIT_TIMES_AFTER_THRESHOLD |
Die Startzeiten für Besuche und Fahrzeuge werden flexibler, aber jeder Besuch ist weiterhin an dasselbe Fahrzeug gebunden und die Reihenfolge der Besuche muss eingehalten werden. Es darf kein Besuch dazwischen oder davor eingefügt werden. |
RELAX_VISIT_TIMES_AND_SEQUENCE_AFTER_THRESHOLD |
Wie RELAX_VISIT_TIMES_AFTER_THRESHOLD, aber die Besuchsreihenfolge ist ebenfalls gelockert: Besuche können nur von diesem Fahrzeug durchgeführt werden, können aber möglicherweise nicht durchgeführt werden. |
RELAX_ALL_AFTER_THRESHOLD |
Wie RELAX_VISIT_TIMES_AND_SEQUENCE_AFTER_THRESHOLD, aber das Fahrzeug ist auch entspannt: Besuche sind ab der Schwelle kostenlos und können möglicherweise nicht durchgeführt werden. |
InputConfig
Geben Sie eine Eingabe für [BatchOptimizeTours][google.maps.routeoptimization.v1.RouteOptimizationService.BatchOptimizeTours] an.
| Felder | |
|---|---|
data_format |
Erforderlich. Das Format der Eingabedaten. |
Union-Feld source. Erforderlich. Für source ist nur einer der folgenden Werte zulässig: |
|
gcs_source |
Ein Google Cloud Storage-Speicherort. Es muss sich um ein einzelnes Objekt (eine Datei) handeln. |
Standort
Kapselt einen Standort (einen geografischen Punkt und eine optionale Richtung).
| Felder | |
|---|---|
lat_lng |
Die geografischen Koordinaten des Wegpunkts. |
heading |
Die Kompassausrichtung, die der Richtung des Verkehrsflusses zugeordnet ist. Mit diesem Wert wird die Straßenseite für die Abholung und das Absetzen angegeben. Die Werte für die Richtung können zwischen 0 und 360 liegen. Dabei steht 0 für Norden, 90 für Osten usw. |
OptimizeToursLongRunningMetadata
Dieser Typ hat keine Felder.
Vorgangsmetadaten für OptimizeToursLongRunning-Aufrufe.
OptimizeToursRequest
Anfrage, die an einen Solver zur Tourenoptimierung gesendet wird und das zu lösende Versandmodell sowie Optimierungsparameter definiert.
| Felder | |
|---|---|
parent |
Erforderlich. Zielprojekt oder Standort zum Anrufen festlegen. Format:
Wenn kein Ort angegeben ist, wird automatisch eine Region ausgewählt. |
timeout |
Wenn dieses Zeitlimit festgelegt ist, gibt der Server eine Antwort zurück, bevor das Zeitlimit abgelaufen ist oder die Serverfrist für synchrone Anfragen erreicht ist, je nachdem, was zuerst eintritt. Bei asynchronen Anfragen generiert der Server (falls möglich) eine Lösung, bevor das Zeitlimit abgelaufen ist. |
model |
Zu lösendes Versandmodell. |
solving_mode |
Der Standardmodus ist |
search_mode |
Der Suchmodus, der zum Beantworten der Anfrage verwendet wurde. |
injected_first_solution_routes[] |
Den Optimierungsalgorithmus dabei unterstützen, eine erste Lösung zu finden, die einer früheren Lösung ähnelt. Das Modell wird eingeschränkt, wenn die erste Lösung erstellt wird. Alle Sendungen, die nicht auf einer Route ausgeführt werden, werden in der ersten Lösung implizit übersprungen, können aber in nachfolgenden Lösungen ausgeführt werden. Die Lösung muss einige grundlegende Gültigkeitsannahmen erfüllen:
Wenn die eingefügte Lösung nicht praktikabel ist, wird nicht unbedingt ein Validierungsfehler zurückgegeben. Stattdessen kann ein Fehler zurückgegeben werden, der auf die Unmöglichkeit hinweist. |
injected_solution_constraint |
Den Optimierungsalgorithmus so einschränken, dass die endgültige Lösung einer vorherigen Lösung ähnelt. Dies kann beispielsweise verwendet werden, um Abschnitte von Routen zu fixieren, die bereits abgeschlossen sind oder abgeschlossen werden sollen, aber nicht geändert werden dürfen. Wenn die eingefügte Lösung nicht praktikabel ist, wird nicht unbedingt ein Validierungsfehler zurückgegeben. Stattdessen kann ein Fehler zurückgegeben werden, der auf die Unmöglichkeit hinweist. |
refresh_details_routes[] |
Wenn nicht leer, werden die angegebenen Routen aktualisiert, ohne dass die zugrunde liegende Reihenfolge der Besuche oder Reisezeiten geändert wird. Es werden nur andere Details aktualisiert. Das Modell wird dadurch nicht gelöst. Seit November 2020 werden damit nur die Polylinien von nicht leeren Routen ausgefüllt. Außerdem muss Die Dieses Feld darf nicht zusammen mit
|
interpret_injected_solutions_using_labels |
Falls zutreffend:
Diese Interpretation gilt für die Felder Bei „true“ dürfen Labels in den folgenden Kategorien höchstens einmal in ihrer Kategorie vorkommen:
Wenn ein Wenn Sie Routenbesuche oder ganze Routen aus einer eingefügten Lösung entfernen, kann sich das auf die impliziten Einschränkungen auswirken. Das kann zu einer Änderung der Lösung, zu Validierungsfehlern oder zu einer Unmöglichkeit führen. HINWEIS: Der Anrufer muss dafür sorgen, dass jede |
consider_road_traffic |
Berücksichtigen Sie die Traffic-Schätzung bei der Berechnung der Felder |
populate_polylines |
Bei „true“ werden Polylinien in Antwort- |
populate_transition_polylines |
Bei „true“ werden Polylinien und Routen-Tokens in der Antwort |
allow_large_deadline_despite_interruption_risk |
Wenn dieser Wert festgelegt ist, kann die Anfrage ein Zeitlimit von bis zu 60 Minuten haben (siehe https://grpc.io/blog/deadlines). Andernfalls beträgt die maximale Frist nur 30 Minuten. Beachten Sie, dass bei Anfragen mit langer Laufzeit ein deutlich höheres (aber immer noch geringes) Risiko besteht, dass sie unterbrochen werden. |
use_geodesic_distances |
Wenn „true“, werden die Entfernungen mit geodätischen Entfernungen anstelle von Google Maps-Entfernungen berechnet und die Reisezeiten mit geodätischen Entfernungen mit einer von |
label |
Label, das zur Identifizierung dieser Anfrage verwendet werden kann und in |
geodesic_meters_per_second |
Wenn |
max_validation_errors |
Kürzt die Anzahl der zurückgegebenen Validierungsfehler. Diese Fehler sind in der Regel an eine INVALID_ARGUMENT-Fehlernutzlast als BadRequest-Fehlerdetail angehängt (https://cloud.google.com/apis/design/errors#error_details), es sei denn, solving_mode=VALIDATE_ONLY: siehe das Feld |
SearchMode
Modus, der das Verhalten der Suche definiert und einen Kompromiss zwischen Latenz und Lösungsqualität darstellt. In allen Modi wird die globale Frist für Anfragen eingehalten.
| Enums | |
|---|---|
SEARCH_MODE_UNSPECIFIED |
Nicht angegebener Suchmodus, entspricht RETURN_FAST. |
RETURN_FAST |
Beenden Sie die Suche, nachdem Sie die erste gute Lösung gefunden haben. |
CONSUME_ALL_AVAILABLE_TIME |
Nutzen Sie die gesamte verfügbare Zeit, um nach besseren Lösungen zu suchen. |
SolvingMode
Definiert, wie der Solver die Anfrage verarbeiten soll. In allen Modi außer VALIDATE_ONLY erhalten Sie bei einer ungültigen Anfrage den Fehler INVALID_REQUEST. Mit max_validation_errors können Sie die Anzahl der zurückgegebenen Fehler begrenzen.
| Enums | |
|---|---|
DEFAULT_SOLVE |
Lösen Sie das Modell. Warnungen können in [OptimizeToursResponse.validation_errors][google.cloud.optimization.v1.OptimizeToursResponse.validation_errors] ausgegeben werden. |
VALIDATE_ONLY |
Das Modell wird nur validiert, ohne es zu lösen. Es werden so viele OptimizeToursResponse.validation_errors wie möglich ausgefüllt. |
DETECT_SOME_INFEASIBLE_SHIPMENTS |
Es wird nur WICHTIG: Hier werden nicht alle nicht durchführbaren Sendungen zurückgegeben, sondern nur diejenigen, die während der Vorverarbeitung als nicht durchführbar erkannt werden. |
TRANSFORM_AND_RETURN_REQUEST |
Dieser Modus funktioniert nur, wenn Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/objectives/make-request. |
OptimizeToursResponse
Antwort nach der Lösung eines Problems zur Tourenoptimierung mit den Routen der einzelnen Fahrzeuge, den übersprungenen Sendungen und den Gesamtkosten der Lösung.
| Felder | |
|---|---|
routes[] |
Für jedes Fahrzeug berechnete Routen. Die i-te Route entspricht dem i-ten Fahrzeug im Modell. |
request_label |
Kopie von |
skipped_shipments[] |
Die Liste aller übersprungenen Sendungen. |
validation_errors[] |
Liste aller Validierungsfehler, die wir unabhängig voneinander erkennen konnten. Weitere Informationen finden Sie unter „MEHRERE FEHLER“ in der Erklärung zur Meldung |
processed_request |
In einigen Fällen ändern wir die eingehende Anfrage, bevor wir sie bearbeiten, z.B. indem wir Kosten hinzufügen. Wenn solving_mode == TRANSFORM_AND_RETURN_REQUEST, wird die geänderte Anfrage hier zurückgegeben. Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/objectives/make-request. |
metrics |
Messwerte für Dauer, Entfernung und Nutzung für diese Lösung. |
Messwerte
Gesamtmesswerte, aggregiert über alle Routen hinweg.
| Felder | |
|---|---|
aggregated_route_metrics |
Über die Routen aggregiert. Jeder Messwert ist die Summe (oder der Maximalwert für Lasten) aller |
skipped_mandatory_shipment_count |
Anzahl der übersprungenen Pflichtlieferungen. |
used_vehicle_count |
Anzahl der verwendeten Fahrzeuge. Hinweis: Wenn eine Fahrzeugroute leer ist und |
earliest_vehicle_start_time |
Die früheste Startzeit für ein Gebrauchtfahrzeug, berechnet als das Minimum aller Gebrauchtfahrzeuge von |
latest_vehicle_end_time |
Die letzte Endzeit für ein Gebrauchtfahrzeug, berechnet als Maximum aller Gebrauchtfahrzeuge von |
costs |
Kosten der Lösung, aufgeschlüsselt nach kostenbezogenen Anfragefeldern. Die Schlüssel sind Protopfade relativ zum OptimizeToursRequest-Eingabe, z. B. „model.shipments.pickups.cost“. Die Werte sind die Gesamtkosten, die durch das entsprechende Kostenfeld generiert werden, aggregiert über die gesamte Lösung. Mit anderen Worten: costs["model.shipments.pickups.cost"] ist die Summe aller Abholkosten für die Lösung. Alle im Modell definierten Kosten werden hier detailliert aufgeführt. Ausgenommen sind Kosten im Zusammenhang mit TransitionAttributes, die seit Januar 2022 nur noch aggregiert ausgewiesen werden. |
total_cost |
Gesamtkosten der Lösung. Die Summe aller Werte in der Kostenübersicht. |
OptimizeToursUriMetadata
Dieser Typ hat keine Felder.
Vorgangsmetadaten für OptimizeToursUri-Aufrufe.
OptimizeToursUriRequest
Eine Anfrage, die von der Methode OptimizeToursUri verwendet wird.
| Felder | |
|---|---|
parent |
Erforderlich. Zielprojekt oder Standort zum Anrufen festlegen. Format:
Wenn kein Ort angegeben ist, wird automatisch eine Region ausgewählt. |
input |
Erforderlich. Der URI des Cloud Storage-Objekts, das |
output |
Erforderlich. Der URI des Cloud Storage-Objekts, das |
OptimizeToursUriResponse
Eine Antwort, die von der Methode OptimizeToursUri zurückgegeben wird.
| Felder | |
|---|---|
output |
Optional. Der URI des Cloud Storage-Objekts, das die Mit dem |
OptimizeToursValidationError
Beschreibt einen Fehler oder eine Warnung, die beim Validieren eines OptimizeToursRequest aufgetreten ist.
| Felder | |
|---|---|
code |
Ein Validierungsfehler wird durch das Paar ( Die Felder nach diesem Abschnitt enthalten weitere Informationen zum Fehler. MULTIPLE ERRORS: Wenn mehrere Fehler vorliegen, werden bei der Validierung mehrere davon ausgegeben. Ähnlich wie bei einem Compiler ist dies ein unvollkommener Prozess. Einige Validierungsfehler sind schwerwiegend und führen dazu, dass der gesamte Validierungsprozess beendet wird. Dies ist u. a. bei STABILITÄT: |
display_name |
Der Anzeigename des Fehlers. |
fields[] |
Ein Fehlerkontext kann 0, 1 (meistens) oder mehrere Felder umfassen. Beispiel: Die erste Abholung von Fahrzeug 4 und Sendung 2 kann so angegeben werden: Die Kardinalität von |
error_message |
Ein für Menschen lesbarer String, der den Fehler beschreibt. Es gibt eine 1:1-Zuordnung zwischen STABILITÄT: Nicht stabil: Die Fehlermeldung, die mit einem bestimmten |
offending_values |
Kann den Wert oder die Werte des Felds enthalten. Diese Option ist nicht immer verfügbar. Sie sollten sich auf keinen Fall darauf verlassen und es nur für das manuelle Debugging von Modellen verwenden. |
FieldReference
Gibt einen Kontext für den Validierungsfehler an. Ein FieldReference bezieht sich immer auf ein bestimmtes Feld in dieser Datei und folgt derselben hierarchischen Struktur. Beispiel: Wir geben Element 2 von start_time_windows von Fahrzeug 5 an:
name: "vehicles" index: 5 sub_field { name: "end_time_windows" index: 2 }
Wir lassen jedoch Top-Level-Entitäten wie OptimizeToursRequest oder ShipmentModel weg, um die Nachricht nicht zu überladen.
| Felder | |
|---|---|
name |
Name des Felds, z.B. „vehicles“. |
sub_field |
Bei Bedarf rekursiv verschachteltes Unterfeld. |
Union-Feld Für |
|
index |
Index des Felds, wenn es wiederholt wird. |
key |
Schlüssel, wenn das Feld eine Zuordnung ist. |
OutputConfig
Geben Sie ein Ziel für die Ergebnisse von [BatchOptimizeTours][google.maps.routeoptimization.v1.RouteOptimizationService.BatchOptimizeTours] an.
| Felder | |
|---|---|
data_format |
Erforderlich. Das Ausgabedatenformat. |
Union-Feld destination. Erforderlich. Für destination ist nur einer der folgenden Werte zulässig: |
|
gcs_destination |
Der Google Cloud Storage-Speicherort, in den die Ausgabe geschrieben wird. |
RouteModifiers
Kapselt eine Reihe optionaler Bedingungen, die bei der Berechnung von Fahrzeugrouten erfüllt werden müssen. Dies ähnelt RouteModifiers in der Google Maps Platform Routes Preferred API. Weitere Informationen finden Sie unter https://developers.google.com/maps/documentation/routes/reference/rest/v2/RouteModifiers.
| Felder | |
|---|---|
avoid_tolls |
Gibt an, ob Mautstraßen nach Möglichkeit vermieden werden sollen. Routen ohne Mautstraßen werden bevorzugt. Gilt nur für motorisierte Fortbewegungsmittel. |
avoid_highways |
Gibt an, ob Autobahnen nach Möglichkeit vermieden werden sollen. Routen ohne Autobahnen werden bevorzugt. Gilt nur für motorisierte Fortbewegungsmittel. |
avoid_ferries |
Gibt an, ob Fähren nach Möglichkeit vermieden werden sollen. Routen ohne Fährverbindungen werden bevorzugt. Gilt nur für motorisierte Fortbewegungsmittel. |
avoid_indoor |
Optional. Gibt an, ob die Navigation in Innenräumen nach Möglichkeit vermieden werden soll. Routen ohne Indoor-Navigation werden bevorzugt. Gilt nur für den Fortbewegungsmodus |
Versand
Der Versand eines einzelnen Artikels von einem seiner Abholorte zu einem seiner Lieferorte. Damit eine Lieferung als ausgeführt gilt, muss ein einzelnes Fahrzeug einen der Abholorte anfahren (und seine freien Kapazitäten entsprechend verringern) und später einen der Lieferorte anfahren (und seine freien Kapazitäten entsprechend wieder erhöhen).
| Felder | |
|---|---|
display_name |
Der benutzerdefinierte Anzeigename der Sendung. Sie kann bis zu 63 Zeichen lang sein und UTF-8-Zeichen enthalten. |
pickups[] |
Eine Reihe von Abholalternativen, die mit der Sendung verknüpft sind. Wenn nichts angegeben ist, muss das Fahrzeug nur einen Standort anfahren, der den Lieferungen entspricht. |
deliveries[] |
Eine Reihe von Lieferalternativen, die mit der Sendung verknüpft sind. Wenn nichts angegeben ist, muss das Fahrzeug nur einen Ort anfahren, der den Abholorten entspricht. |
load_demands |
Anforderungen an die Ladung (z. B. Gewicht, Volumen, Anzahl der Paletten usw.). Die Schlüssel in der Map sollten Kennungen sein, die den Typ der entsprechenden Last beschreiben, idealerweise auch mit den Einheiten. Beispiele: „weight_kg“, „volume_gallons“, „pallet_count“ usw. Wenn ein bestimmter Schlüssel nicht in der Zuordnung enthalten ist, wird die entsprechende Ladung als null betrachtet. |
allowed_vehicle_indices[] |
Die Menge der Fahrzeuge, die diese Sendung ausführen können. Wenn das Feld leer ist, kann die Aktion von allen Fahrzeugen ausgeführt werden. Fahrzeuge werden anhand ihres Index in der |
costs_per_vehicle[] |
Gibt die Kosten an, die anfallen, wenn diese Sendung mit dem jeweiligen Fahrzeug zugestellt wird. Falls angegeben, muss es ENTWEDER:
Diese Kosten müssen in derselben Einheit wie |
costs_per_vehicle_indices[] |
Die Indexe der Fahrzeuge, auf die |
pickup_to_delivery_absolute_detour_limit |
Gibt die maximale absolute Umwegzeit im Vergleich zum kürzesten Weg von der Abholung bis zur Zustellung an. Wenn angegeben, muss der Wert nicht negativ sein und die Sendung muss mindestens eine Abholung und eine Zustellung enthalten. Sei t beispielsweise die kürzeste Zeit, die benötigt wird, um von der ausgewählten Abholalternative direkt zur ausgewählten Lieferalternative zu gelangen. Die Einstellung Wenn sowohl relative als auch absolute Limits für dieselbe Sendung angegeben sind, wird für jedes mögliche Abhol-/Lieferpaar das restriktivere Limit verwendet. Seit Oktober 2017 werden Umwege nur unterstützt, wenn die Reisezeiten nicht von Fahrzeugen abhängen. |
pickup_to_delivery_time_limit |
Gibt die maximale Dauer vom Beginn der Abholung bis zum Beginn der Zustellung einer Sendung an. Wenn angegeben, muss der Wert nicht negativ sein und die Sendung muss mindestens eine Abholung und eine Zustellung enthalten. Das hängt weder davon ab, welche Alternativen für die Abholung und Zustellung ausgewählt sind, noch von der Fahrzeuggeschwindigkeit. Diese Einschränkung kann zusammen mit Einschränkungen für die maximale Umleitung angegeben werden. Die Lösung berücksichtigt dann beide Spezifikationen. |
shipment_type |
Nicht leerer String, der einen „Typ“ für diese Sendung angibt. Mit dieser Funktion können Inkompatibilitäten oder Anforderungen zwischen Unterscheidet sich von |
label |
Gibt ein Label für diese Sendung an. Dieses Label wird in der Antwort im |
ignore |
Wenn „true“ angegeben ist, überspringen Sie diese Sendung, wenden Sie aber keine Wenn Sie eine Sendung ignorieren, führt das zu einem Validierungsfehler, wenn im Modell Eine Sendung, die in |
penalty_cost |
Wenn die Lieferung nicht abgeschlossen wird, wird diese Strafe zu den Gesamtkosten der Routen hinzugerechnet. Eine Sendung gilt als abgeschlossen, wenn eine der Abhol- und Lieferalternativen besucht wurde. Die Kosten können in derselben Einheit wie alle anderen kostenbezogenen Felder im Modell angegeben werden und müssen positiv sein. WICHTIG: Wenn diese Strafe nicht angegeben ist, wird sie als unendlich betrachtet, d.h. die Sendung muss abgeschlossen werden. |
pickup_to_delivery_relative_detour_limit |
Gibt die maximale relative Umwegzeit im Vergleich zum kürzesten Weg von der Abholung bis zur Zustellung an. Wenn angegeben, muss der Wert nicht negativ sein und die Sendung muss mindestens eine Abholung und eine Zustellung enthalten. Sei t beispielsweise die kürzeste Zeit, die benötigt wird, um von der ausgewählten Abholalternative direkt zur ausgewählten Lieferalternative zu gelangen. Die Einstellung Wenn sowohl relative als auch absolute Limits für dieselbe Sendung angegeben sind, wird für jedes mögliche Abhol-/Lieferpaar das restriktivere Limit verwendet. Seit Oktober 2017 werden Umwege nur unterstützt, wenn die Reisezeiten nicht von Fahrzeugen abhängen. |
Laden
Bei einem Besuch kann der Fahrzeugladung eine vordefinierte Menge hinzugefügt werden, wenn es sich um eine Abholung handelt, oder abgezogen werden, wenn es sich um eine Lieferung handelt. In dieser Nachricht wird ein solcher Betrag definiert. load_demands ansehen.
| Felder | |
|---|---|
amount |
Der Betrag, um den sich die Ladung des Fahrzeugs, das den entsprechenden Besuch durchführt, ändert. Da es sich um eine Ganzzahl handelt, sollten Nutzer eine geeignete Einheit auswählen, um einen Präzisionsverlust zu vermeiden. Muss ≥ 0 sein. |
VisitRequest
Anfrage für einen Besuch, der mit einem Fahrzeug durchgeführt werden kann: Sie hat einen geografischen Standort (oder zwei, siehe unten), Öffnungs- und Schließzeiten, die durch Zeitfenster dargestellt werden, und eine Dienstleistungsdauer (Zeit, die das Fahrzeug benötigt, wenn es Waren abholt oder abliefert).
| Felder | |
|---|---|
arrival_location |
Der geografische Standort, an dem das Fahrzeug bei der Ausführung dieses |
arrival_waypoint |
Der Wegpunkt, an dem das Fahrzeug bei Ausführung dieses |
departure_location |
Der geografische Standort, an dem das Fahrzeug nach Abschluss dieses |
departure_waypoint |
Der Wegpunkt, an dem das Fahrzeug nach Abschluss dieser |
tags[] |
Gibt Tags an, die an die Besuchsaufforderung angehängt werden. Leere oder doppelte Strings sind nicht zulässig. |
time_windows[] |
Zeitfenster, die die Ankunftszeit an einem Standort einschränken. Ein Fahrzeug kann auch außerhalb des Ankunftszeitfensters abfahren. Ankunftszeit + Dauer müssen also nicht innerhalb eines Zeitfensters liegen. Das kann zu Wartezeiten führen, wenn das Fahrzeug vor Wenn Die Zeitfenster müssen disjunkt sein, d.h., sie dürfen sich nicht überschneiden oder aneinandergrenzen und müssen in aufsteigender Reihenfolge angegeben werden.
|
duration |
Dauer des Besuchs, d.h. Zeit, die das Fahrzeug zwischen Ankunft und Abfahrt verbringt (muss zur möglichen Wartezeit addiert werden; siehe |
cost |
Kosten für die Bearbeitung dieser Besuchsaufforderung auf einer Fahrzeugroute. Damit können Sie für jede alternative Abholung oder Lieferung einer Sendung unterschiedliche Kosten bezahlen. Die Kosten müssen in derselben Einheit wie |
load_demands |
Ladeanforderungen dieser Besuchsaufforderung. Dieses Feld entspricht dem Feld |
visit_types[] |
Gibt die Arten des Besuchs an. Damit kann zusätzliche Zeit zugewiesen werden, die ein Fahrzeug für diesen Besuch benötigt (siehe Ein Typ kann nur einmal vorkommen. |
label |
Gibt ein Label für diese |
avoid_u_turns |
Gibt an, ob an diesem Ort Wendemanöver auf Fahrrouten vermieden werden sollen. Das Vermeiden von U-Turns erfolgt nach bestem Gewissen und kann nicht garantiert werden. Dies ist eine experimentelle Funktion und das Verhalten kann sich ändern. Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/u-turn-avoidance/make-request. |
ShipmentModel
Ein Versandmodell enthält eine Reihe von Sendungen, die von einer Reihe von Fahrzeugen ausgeführt werden müssen, wobei die Gesamtkosten minimiert werden. Die Gesamtkosten sind die Summe aus:
- die Kosten für die Routenplanung der Fahrzeuge (Summe der Kosten pro Gesamtzeit, Kosten pro Reisezeit und Fixkosten für alle Fahrzeuge).
- die Strafen für nicht durchgeführte Lieferungen.
- die Kosten für die globale Dauer der Sendungen
| Felder | |
|---|---|
shipments[] |
Eine Reihe von Sendungen, die im Modell ausgeführt werden müssen. |
vehicles[] |
Eine Reihe von Fahrzeugen, die für Besuche verwendet werden können. |
objectives[] |
Die Gruppe von Zielvorhaben für dieses Modell, die in Kosten umgewandelt werden. Wenn nicht leer, muss das Eingabemodell kostenlos sein. Verwenden Sie Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/objectives/make-request. |
global_start_time |
Globale Start- und Endzeit des Modells: Zeiten außerhalb dieses Bereichs können nicht als gültig betrachtet werden. Der Zeitraum des Modells darf nicht länger als ein Jahr sein. Das heißt, zwischen Wenn Sie |
global_end_time |
Wenn kein Wert angegeben ist, wird standardmäßig 00:00:00 UTC, 1. Januar 1971 (d. h. Sekunden: 31536000, Nanosekunden: 0) verwendet. |
global_duration_cost_per_hour |
Die „globale Dauer“ des Gesamtplans ist die Differenz zwischen der frühesten effektiven Startzeit und der spätesten effektiven Endzeit aller Fahrzeuge. Nutzer können dieser Menge Kosten pro Stunde zuweisen, um beispielsweise die frühestmögliche Fertigstellung des Jobs zu optimieren. Diese Kosten müssen in derselben Einheit wie |
duration_distance_matrices[] |
Gibt die im Modell verwendeten Dauer- und Distanzmatrizen an. Wenn dieses Feld leer ist, werden stattdessen Google Maps- oder geodätische Distanzen verwendet, je nach Wert des Felds Typische Syntax:
|
duration_distance_matrix_src_tags[] |
Tags, die die Quellen der Dauer- und Distanzmatrizen definieren; Tags entsprechen |
duration_distance_matrix_dst_tags[] |
Tags, die die Ziele der Dauer- und Distanzmatrizen definieren; Tags entsprechen |
transition_attributes[] |
Dem Modell wurden Übergangsattribute hinzugefügt. |
shipment_type_incompatibilities[] |
Sets mit inkompatiblen shipment_types (siehe |
shipment_type_requirements[] |
Sätze von |
precedence_rules[] |
Eine Reihe von Vorrangregeln, die im Modell durchgesetzt werden müssen. WICHTIG: Durch die Verwendung von Vorrangregeln wird die Größe des Problems, das optimiert werden kann, eingeschränkt. Anfragen mit Vorrangregeln, die viele Sendungen enthalten, können abgelehnt werden. |
max_active_vehicles |
Beschränkt die maximale Anzahl aktiver Fahrzeuge. Ein Fahrzeug ist aktiv, wenn auf seiner Route mindestens eine Sendung transportiert wird. So kann die Anzahl der Routen begrenzt werden, wenn es weniger Fahrer als Fahrzeuge gibt und die Fahrzeugflotte heterogen ist. Bei der Optimierung wird dann die beste Teilmenge von Fahrzeugen ausgewählt. Muss strikt positiv sein. |
DurationDistanceMatrix
Gibt eine Matrix mit Dauer und Entfernung von den Startorten der Besuche und Fahrzeuge zu den Endorten der Besuche und Fahrzeuge an.
| Felder | |
|---|---|
rows[] |
Gibt die Zeilen der Matrix für Dauer und Entfernung an. Es muss so viele Elemente wie |
vehicle_start_tag |
Tag, das definiert, für welche Fahrzeuge diese Dauer- und Distanzmatrix gilt. Wenn das Feld leer ist, gilt die Matrix für alle Fahrzeuge. In diesem Fall kann es nur eine Matrix geben. Jeder Fahrzeugstart muss genau einer Matrix entsprechen. Das bedeutet, dass genau eines der Alle Matrizen müssen einen anderen |
Zeile
Gibt eine Zeile der Matrix für Dauer und Entfernung an.
| Felder | |
|---|---|
durations[] |
Dauerwerte für eine bestimmte Zeile. Es muss so viele Elemente wie |
meters[] |
Entfernungswerte für eine bestimmte Zeile. Wenn sich im Modell keine Kosten oder Einschränkungen auf Entfernungen beziehen, kann dieses Feld leer gelassen werden. Andernfalls muss es so viele Elemente wie |
Ziel
Zielvorhaben ersetzen das Kostenmodell vollständig und sind daher nicht mit bestehenden Kosten kompatibel. Jedes Ziel wird einer Reihe vordefinierter Kosten für z.B. Fahrzeuge, Sendungen oder Übergangsattribute zugeordnet.
Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/objectives/make-request.
| Felder | |
|---|---|
type |
Der Typ des Zielvorhabens. |
weight |
Wie viel dieses Zielvorhaben im Verhältnis zu den anderen zählen soll. Das kann eine beliebige nicht negative Zahl sein. Die Summe der Gewichte muss nicht 1 ergeben. Die Standardeinstellung für Gewichte ist 1,0. |
Typ
Der Zielvorhabentyp, der einer Reihe von Kosten zugeordnet wird.
| Enums | |
|---|---|
DEFAULT |
Es wird ein Standardsatz von Kosten verwendet, um eine angemessene Lösung zu gewährleisten. Hinweis: Dieses Ziel kann allein verwendet werden, wird aber auch immer mit dem Gewicht 1,0 als Baseline zu den vom Nutzer angegebenen Zielen hinzugefügt, sofern es nicht bereits vorhanden ist. |
MIN_DISTANCE |
„MIN“-Zielvorhaben. Minimieren Sie die insgesamt zurückgelegte Strecke. |
MIN_WORKING_TIME |
Minimieren Sie die gesamte Arbeitszeit, summiert über alle Fahrzeuge. |
MIN_TRAVEL_TIME |
Wie oben, aber nur mit Fokus auf die Reisezeit. |
MIN_NUM_VEHICLES |
Minimieren Sie die Anzahl der verwendeten Fahrzeuge. |
PrecedenceRule
Eine Vorrangregel zwischen zwei Ereignissen (jedes Ereignis ist die Abholung oder die Zustellung einer Sendung): Das „zweite“ Ereignis muss mindestens offset_duration nach dem Start des „ersten“ Ereignisses beginnen.
Mehrere Präzedenzen können sich auf dieselben (oder ähnliche) Ereignisse beziehen, z.B.: „Abholung von B erfolgt nach Lieferung von A“ und „Abholung von C erfolgt nach Abholung von B“.
Außerdem gelten Vorrangregeln nur, wenn beide Sendungen ausgeführt werden. Andernfalls werden sie ignoriert.
| Felder | |
|---|---|
first_is_delivery |
Gibt an, ob das „first“-Ereignis eine Zustellung ist. |
second_is_delivery |
Gibt an, ob es sich beim „second“-Ereignis um eine Zustellung handelt. |
offset_duration |
Die Zeitverschiebung zwischen dem ersten und dem zweiten Ereignis. Sie kann negativ sein. |
first_index |
Versandindex des „ersten“ Ereignisses. Dieses Feld muss angegeben werden. |
second_index |
Versandindex des „zweiten“ Ereignisses. Dieses Feld muss angegeben werden. |
ShipmentRoute
Die Route eines Fahrzeugs kann entlang der Zeitachse so zerlegt werden (wir gehen von n Besuchen aus):
| | | | | T[2], | | |
| Transition | Visit #0 | | | V[2], | | |
| #0 | aka | T[1] | V[1] | ... | V[n-1] | T[n] |
| aka T[0] | V[0] | | | V[n-2],| | |
| | | | | T[n-1] | | |
^ ^ ^ ^ ^ ^ ^ ^
vehicle V[0].start V[0].end V[1]. V[1]. V[n]. V[n]. vehicle
start (arrival) (departure) start end start end end
Wir unterscheiden zwischen:
- „Pünktliche Ereignisse“ wie Start und Ende des Fahrzeugs sowie Start und Ende jedes Besuchs (Ankunft und Abfahrt). Sie treten zu einem bestimmten Zeitpunkt auf.
- „Zeitintervalle“ wie die Besuche selbst und der Übergang zwischen Besuchen. Zeitintervalle können manchmal eine Dauer von null haben, d. h. sie beginnen und enden in derselben Sekunde. Oft haben sie jedoch eine positive Dauer.
Invarianten:
- Bei n Besuchen gibt es n+1 Übergänge.
- Ein Besuch ist immer von einem Übergang davor (derselbe Index) und einem Übergang danach (Index + 1) umgeben.
- Auf den Fahrzeugstart folgt immer Übergang 0.
- Dem Fahrzeugende geht immer der Übergang #n voraus.
Hier sehen Sie, was bei einer Transition und einer Visit passiert:
---+-------------------------------------+-----------------------------+-->
| TRANSITION[i] | VISIT[i] |
| | |
| * TRAVEL: the vehicle moves from | PERFORM the visit: |
| VISIT[i-1].departure_location to | |
| VISIT[i].arrival_location, which | * Spend some time: |
| takes a given travel duration | the "visit duration". |
| and distance | |
| | * Load or unload |
| * BREAKS: the driver may have | some quantities from the |
| breaks (e.g. lunch break). | vehicle: the "demand". |
| | |
| * WAIT: the driver/vehicle does | |
| nothing. This can happen for | |
| many reasons, for example when | |
| the vehicle reaches the next | |
| event's destination before the | |
| start of its time window | |
| | |
| * DELAY: *right before* the next | |
| arrival. E.g. the vehicle and/or | |
| driver spends time unloading. | |
| | |
---+-------------------------------------+-----------------------------+-->
^ ^ ^
V[i-1].end V[i].start V[i].end
So können TRAVEL, BREAKS, DELAY und WAIT während eines Übergangs angeordnet werden.
- Sie überschneiden sich nicht.
- Die DELAY ist eindeutig und muss ein zusammenhängender Zeitraum unmittelbar vor dem nächsten Besuch (oder dem Ende des Fahrzeugs) sein. Daher reicht es aus, die Verzögerungsdauer zu kennen, um die Start- und Endzeit zu ermitteln.
- Die PAUSEN sind zusammenhängende, sich nicht überschneidende Zeiträume. In der Antwort werden die Startzeit und die Dauer jeder Pause angegeben.
- TRAVEL und WAIT sind „unterbrechbar“: Sie können während dieses Übergangs mehrmals unterbrochen werden. Clients können davon ausgehen, dass die Reise „so schnell wie möglich“ stattfindet und dass die verbleibende Zeit mit „Warten“ ausgefüllt wird.
Ein komplexes Beispiel:
TRANSITION[i]
--++-----+-----------------------------------------------------------++-->
|| | | | | | | ||
|| T | B | T | | B | | D ||
|| r | r | r | W | r | W | e ||
|| a | e | a | a | e | a | l ||
|| v | a | v | i | a | i | a ||
|| e | k | e | t | k | t | y ||
|| l | | l | | | | ||
|| | | | | | | ||
--++-----------------------------------------------------------------++-->
| Felder | |
|---|---|
vehicle_index |
Das Fahrzeug, das die Route fährt, identifiziert durch seinen Index in der Quell- |
vehicle_label |
Label des Fahrzeugs, das diese Route fährt. Entspricht |
vehicle_start_time |
Uhrzeit, zu der das Fahrzeug seine Route beginnt. |
vehicle_end_time |
Uhrzeit, zu der das Fahrzeug seine Route beendet. |
visits[] |
Geordnete Reihenfolge von Besuchen, die eine Route darstellen. „visits[i]“ ist der i-te Besuch auf der Route. Wenn dieses Feld leer ist, gilt das Fahrzeug als nicht verwendet. |
transitions[] |
Geordnete Liste der Übergänge für die Route. |
has_traffic_infeasibilities |
Wenn Die Ankunft am Zielort wird aufgrund der erhöhten geschätzten Reisezeit von |
route_polyline |
Die codierte Polylinien-Darstellung der Route. Dieses Feld wird nur ausgefüllt, wenn |
breaks[] |
Pausen, die für das Fahrzeug auf dieser Route geplant sind. Die |
metrics |
Messwerte für Dauer, Distanz und Belastung für diese Route. Die Felder von |
vehicle_fullness |
Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
route_costs |
Kosten der Route, aufgeschlüsselt nach kostenbezogenen Anfragefeldern. Die Schlüssel sind Protopfade relativ zum Eingabe-OptimizeToursRequest, z. B. „model.shipments.pickups.cost“. Die Werte sind die Gesamtkosten, die durch das entsprechende Kostenfeld generiert werden, aggregiert über die gesamte Route. Mit anderen Worten: costs["model.shipments.pickups.cost"] ist die Summe aller Abholkosten für die Route. Alle im Modell definierten Kosten werden hier detailliert aufgeführt. Ausgenommen sind Kosten im Zusammenhang mit TransitionAttributes, die seit Januar 2022 nur noch zusammengefasst angegeben werden. |
route_total_cost |
Gesamtkosten der Route. Die Summe aller Kosten in der Kostenübersicht. |
Pause
Daten, die die Ausführung einer Pause darstellen.
| Felder | |
|---|---|
start_time |
Startzeit einer Pause. |
duration |
Dauer einer Pause. |
EncodedPolyline
Die codierte Darstellung einer Polylinie. Weitere Informationen zur Polyline-Codierung finden Sie hier: https://developers.google.com/maps/documentation/utilities/polylinealgorithm und https://developers.google.com/maps/documentation/javascript/reference/geometry#encoding.
| Felder | |
|---|---|
points |
String, der die codierten Punkte der Polylinie darstellt. |
Übergang
Übergang zwischen zwei Ereignissen auf der Route. Siehe Beschreibung von ShipmentRoute.
Wenn das Fahrzeug keine start_location und/oder end_location hat, sind die entsprechenden Fahrtenmesswerte 0.
| Felder | |
|---|---|
travel_duration |
Reisedauer während dieser Übergangszeit. |
travel_distance_meters |
Zurückgelegte Strecke während des Übergangs. |
traffic_info_unavailable |
Wenn Traffic über |
delay_duration |
Summe der Verzögerungsdauern, die auf diesen Übergang angewendet werden. Falls vorhanden, beginnt die Verzögerung genau |
break_duration |
Summe der Dauer der Pausen, die während dieses Übergangs aufgetreten sind (falls vorhanden). Details zur Startzeit und Dauer der einzelnen Pausen werden in |
wait_duration |
Die Wartezeit während dieser Umstellung. Die Wartezeit entspricht der Leerlaufzeit und umfasst keine Pausenzeit. Beachten Sie außerdem, dass diese Wartezeit in mehrere nicht zusammenhängende Intervalle unterteilt sein kann. |
total_duration |
Gesamtdauer der Umstellung (zur Übersicht). Das entspricht:
|
start_time |
Startzeit dieses Übergangs. |
route_polyline |
Die codierte Polylinien-Darstellung der Route, die während der Übergangsphase gefahren wurde. Dieses Feld wird nur ausgefüllt, wenn |
route_token |
Nur Ausgabe. Ein vertrauliches Token, das an das Navigation SDK übergeben werden kann, um die Route während der Navigation zu rekonstruieren und bei einer Umleitung die ursprüngliche Absicht beim Erstellen der Route zu berücksichtigen. Behandeln Sie dieses Token als intransparenten Blob. Vergleichen Sie den Wert nicht über Anfragen hinweg, da er sich ändern kann, auch wenn der Dienst genau dieselbe Route zurückgibt. Dieses Feld wird nur ausgefüllt, wenn |
vehicle_loads |
Fahrzeugladungen während dieser Umstellung für jeden Typ, der entweder in der Die Ladungen während des ersten Übergangs sind die Startladungen der Fahrzeugroute. Nach jedem Besuch werden die |
VehicleLoad
Gibt die tatsächliche Beladung des Fahrzeugs an einem bestimmten Punkt auf der Route für einen bestimmten Typ (siehe Transition.vehicle_loads) zurück.
| Felder | |
|---|---|
amount |
Die Belastung des Fahrzeugs für den angegebenen Typ. Die Einheit der Last wird in der Regel durch den Typ angegeben. |
Aufrufen
Ein Besuch, der während einer Route durchgeführt wird. Dieser Besuch entspricht einer Abholung oder Lieferung eines Shipment.
| Felder | |
|---|---|
shipment_index |
Index des Felds |
is_pickup |
Wenn „true“, entspricht der Besuch der Abholung eines |
visit_request_index |
Index von |
start_time |
Uhrzeit, zu der der Besuch beginnt. Das Fahrzeug kann jedoch auch früher am Zielort eintreffen. Die Zeiten stimmen mit der |
load_demands |
Die Gesamtnachfrage nach Besuchen als Summe der Versand- und der Besuchsanträge |
detour |
Zusätzliche Umwegzeit aufgrund der Lieferungen, die auf der Route vor dem Besuch angefahren werden, und der potenziellen Wartezeit, die durch Zeitfenster entsteht. Wenn der Besuch eine Lieferung ist, wird der Umweg vom entsprechenden Abholbesuch aus berechnet und entspricht: Andernfalls wird sie aus dem Fahrzeug |
shipment_label |
Kopie der entsprechenden |
visit_label |
Kopie der entsprechenden |
injected_solution_location_token |
Ein intransparentes Token, das Informationen zu einem besuchten Ort enthält. Dieses Feld kann in den Besuchen der Ergebnisrouten ausgefüllt werden, wenn Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/u-turn-avoidance/make-request. |
ShipmentTypeIncompatibility
Gibt Inkompatibilitäten zwischen Sendungen in Abhängigkeit von ihrem shipment_type an. Das Erscheinen inkompatibler Sendungen auf derselben Route ist je nach Inkompatibilitätsmodus eingeschränkt.
| Felder | |
|---|---|
types[] |
Liste der inkompatiblen Typen. Zwei Sendungen mit unterschiedlichen |
incompatibility_mode |
Auf die Inkompatibilität angewendeter Modus. |
IncompatibilityMode
Modi, die definieren, wie das Erscheinen inkompatibler Sendungen auf derselben Route eingeschränkt wird.
| Enums | |
|---|---|
INCOMPATIBILITY_MODE_UNSPECIFIED |
Nicht angegebener Inkompatibilitätsmodus. Dieser Wert sollte niemals verwendet werden. |
NOT_PERFORMED_BY_SAME_VEHICLE |
In diesem Modus können zwei Sendungen mit inkompatiblen Typen niemals dasselbe Fahrzeug nutzen. |
NOT_IN_SAME_VEHICLE_SIMULTANEOUSLY |
In diesem Modus können zwei Sendungen mit inkompatiblen Typen niemals gleichzeitig auf demselben Fahrzeug transportiert werden:
|
ShipmentTypeRequirement
Gibt Anforderungen zwischen Sendungen basierend auf ihrem „shipment_type“ an. Die Details der Anforderung werden durch den Anforderungsmodus definiert.
| Felder | |
|---|---|
required_shipment_type_alternatives[] |
Liste der alternativen Versandarten, die von |
dependent_shipment_types[] |
Für alle Sendungen mit einem Typ im Feld HINWEIS: Ketten von Anforderungen, bei denen eine |
requirement_mode |
Auf die Anforderung angewendeter Modus. |
RequirementMode
Modi, die das Erscheinungsbild von abhängigen Sendungen auf einer Route definieren.
| Enums | |
|---|---|
REQUIREMENT_MODE_UNSPECIFIED |
Nicht angegebener Anforderungsmodus. Dieser Wert sollte niemals verwendet werden. |
PERFORMED_BY_SAME_VEHICLE |
In diesem Modus müssen alle „abhängigen“ Sendungen dasselbe Fahrzeug wie mindestens eine ihrer „erforderlichen“ Sendungen nutzen. |
IN_SAME_VEHICLE_AT_PICKUP_TIME |
Im Für die Abholung einer „abhängigen“ Sendung muss daher Folgendes gelten:
|
IN_SAME_VEHICLE_AT_DELIVERY_TIME |
Wie zuvor, nur dass für die „abhängigen“ Sendungen zum Zeitpunkt der Lieferung eine „erforderliche“ Sendung auf dem Fahrzeug vorhanden sein muss. |
SkippedShipment
Gibt Details zu nicht ausgeführten Sendungen in einer Lösung an. Bei trivialen Fällen und/oder wenn wir die Ursache für das Überspringen ermitteln können, geben wir den Grund hier an.
| Felder | |
|---|---|
index |
Der Index entspricht dem Index der Sendung in der Quelle |
label |
Kopie der entsprechenden |
reasons[] |
Eine Liste mit Gründen, warum die Sendung übersprungen wurde. Siehe Kommentar oben |
penalty_cost |
Dies ist eine Kopie von Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
estimated_incompatible_vehicle_ratio |
Geschätztes Verhältnis der Fahrzeuge, die diese Sendung aus mindestens einem der folgenden Gründe nicht transportieren können. Hinweis: Dieses Feld wird nur ausgefüllt, wenn die Gründe ein Fahrzeug betreffen. Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
Grund
Wenn wir erklären können, warum die Sendung übersprungen wurde, werden die Gründe hier aufgeführt. Wenn der Grund nicht für alle Fahrzeuge derselbe ist, enthält reason mehr als ein Element. Für eine übersprungene Sendung dürfen keine doppelten Gründe angegeben werden, d.h. alle Felder müssen gleich sein, mit Ausnahme von example_vehicle_index. Beispiel:
reasons {
code: DEMAND_EXCEEDS_VEHICLE_CAPACITY
example_vehicle_index: 1
example_exceeded_capacity_type: "Apples"
}
reasons {
code: DEMAND_EXCEEDS_VEHICLE_CAPACITY
example_vehicle_index: 3
example_exceeded_capacity_type: "Pears"
}
reasons {
code: CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DISTANCE_LIMIT
example_vehicle_index: 1
}
Die übersprungene Sendung ist mit keinem Fahrzeug kompatibel. Die Gründe können für alle Fahrzeuge unterschiedlich sein, aber die Kapazität für „Äpfel“ würde bei mindestens einem Fahrzeug (einschließlich Fahrzeug 1) überschritten, die Kapazität für „Birnen“ bei mindestens einem Fahrzeug (einschließlich Fahrzeug 3) und die Entfernungsgrenze bei mindestens einem Fahrzeug (einschließlich Fahrzeug 1).
| Felder | |
|---|---|
code |
Weitere Informationen finden Sie in den Kommentaren des Codes. |
example_vehicle_indices[] |
Wie Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
example_exceeded_capacity_type |
Wenn der Grundcode |
example_vehicle_index |
Wenn der Grund mit einer Inkompatibilität zwischen Sendung und Fahrzeug zusammenhängt, enthält dieses Feld den Index eines relevanten Fahrzeugs. |
Code
Code zur Identifizierung des Grundtyps. Die Reihenfolge ist hier nicht wichtig. Insbesondere wird nicht angegeben, ob ein bestimmter Grund vor einem anderen in der Lösung angezeigt wird, wenn beide zutreffen.
| Enums | |
|---|---|
CODE_UNSPECIFIED |
Sollte nicht verwendet werden. |
NO_VEHICLE |
Im Modell ist kein Fahrzeug vorhanden, sodass alle Sendungen nicht durchführbar sind. |
DEMAND_EXCEEDS_VEHICLE_CAPACITY |
Die Nachfrage nach der Sendung übersteigt die Kapazität eines Fahrzeugs für einige Kapazitätstypen, darunter example_exceeded_capacity_type. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DISTANCE_LIMIT |
Die für den Transport erforderliche Mindeststrecke, d.h. vom Für diese Berechnung werden die geodätischen Distanzen verwendet. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DURATION_LIMIT |
Die für diese Sendung erforderliche Mindestzeit, einschließlich Reisezeit, Wartezeit und Servicezeit, überschreitet die Hinweis: Die Reisezeit wird im Best-Case-Szenario berechnet, nämlich als geodätische Entfernung × 36 m/s (ungefähr 130 km/h). |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_TRAVEL_DURATION_LIMIT |
Wie oben, aber wir vergleichen nur die Mindestfahrzeit und die travel_duration_limit des Fahrzeugs. |
CANNOT_BE_PERFORMED_WITHIN_VEHICLE_TIME_WINDOWS |
Das Fahrzeug kann diese Lieferung im besten Fall (siehe CANNOT_BE_PERFORMED_WITHIN_VEHICLE_DURATION_LIMIT für die Zeitberechnung) nicht ausführen, wenn es zum frühestmöglichen Startzeitpunkt startet: Die Gesamtzeit würde dazu führen, dass das Fahrzeug nach dem spätestmöglichen Endzeitpunkt ankommt. |
VEHICLE_NOT_ALLOWED |
Das Feld allowed_vehicle_indices der Sendung ist nicht leer und dieses Fahrzeug gehört nicht dazu. |
VEHICLE_IGNORED |
Das Feld Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
SHIPMENT_IGNORED |
Das Feld Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
SKIPPED_IN_INJECTED_SOLUTION_CONSTRAINT |
Die Lieferung wird in Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
VEHICLE_ROUTE_IS_FULLY_SEQUENCE_CONSTRAINED |
Die in Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
ZERO_PENALTY_COST |
Für die Sendung fallen keine Strafgebühren an. Das kann als erweiterte Modellierungsoption nützlich sein, aber auch nachträglich erklären, warum eine Sendung übersprungen wurde. Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
TimeWindow
Zeitfenster schränken die Zeit eines Ereignisses ein, z. B. die Ankunftszeit bei einem Besuch oder die Start- und Endzeit eines Fahrzeugs.
Mit den harten Zeitfenstergrenzen start_time und end_time wird die früheste und späteste Zeit des Ereignisses festgelegt, sodass start_time <= event_time <=
end_time gilt. Die Untergrenze des weichen Zeitfensters, soft_start_time, drückt eine Präferenz dafür aus, dass das Ereignis nach oder zum Zeitpunkt soft_start_time eintritt. Dies wird durch Kosten ausgedrückt, die proportional dazu sind, wie lange vor soft_start_time das Ereignis eintritt. Die Obergrenze des weichen Zeitfensters, soft_end_time, drückt eine Präferenz dafür aus, dass das Ereignis vor oder zum Zeitpunkt soft_end_time eintritt. Die Kosten sind proportional dazu, wie lange nach soft_end_time das Ereignis eintritt. start_time, end_time, soft_start_time und soft_end_time müssen innerhalb der globalen Zeitlimits liegen (siehe ShipmentModel.global_start_time und ShipmentModel.global_end_time) und Folgendes berücksichtigen:
0 <= `start_time` <= `end_time` and
0 <= `start_time` <= `soft_start_time` and
0 <= `soft_end_time` <= `end_time`.
| Felder | |
|---|---|
start_time |
Die Startzeit des harten Zeitfensters. Wenn nicht angegeben, wird der Wert auf |
end_time |
Das Ende des harten Zeitfensters. Wenn nicht angegeben, wird der Wert auf |
soft_start_time |
Die Soft-Startzeit des Zeitfensters. |
soft_end_time |
Das weiche Ende des Zeitfensters. |
cost_per_hour_before_soft_start_time |
Ein Kostenbetrag pro Stunde, der anderen Kosten im Modell hinzugefügt wird, wenn das Ereignis vor „soft_start_time“ eintritt. Er wird so berechnet: Diese Kosten müssen positiv sein und das Feld kann nur festgelegt werden, wenn „soft_start_time“ festgelegt wurde. |
cost_per_hour_after_soft_end_time |
Kosten pro Stunde, die anderen Kosten im Modell hinzugefügt werden, wenn das Ereignis nach Diese Kosten müssen positiv sein und das Feld kann nur festgelegt werden, wenn |
TransitionAttributes
Gibt Attribute von Übergängen zwischen zwei aufeinanderfolgenden Besuchen auf einer Route an. Für denselben Übergang können mehrere TransitionAttributes gelten. In diesem Fall werden alle zusätzlichen Kosten addiert und die strengste Einschränkung oder das strengste Limit wird angewendet (gemäß der natürlichen UND-Semantik).
| Felder | |
|---|---|
src_tag |
Tags, die die Menge der (src->dst)-Übergänge definieren, auf die sich diese Attribute beziehen. Ein Quellbesuch oder Fahrzeugstart stimmt überein, wenn sein |
excluded_src_tag |
|
dst_tag |
Ein Zielbesuch oder Fahrzeugende stimmt überein, wenn |
excluded_dst_tag |
|
cost |
Gibt die Kosten für die Durchführung dieses Übergangs an. Diese Einheit ist dieselbe wie bei allen anderen Kosten im Modell und darf nicht negativ sein. Sie wird zusätzlich zu allen anderen bestehenden Kosten berechnet. |
cost_per_kilometer |
Gibt die Kosten pro Kilometer an, die für die während dieser Übergangsphase zurückgelegte Strecke berechnet werden. Sie wird zu allen |
distance_limit |
Gibt ein Limit für die zurückgelegte Strecke während dieses Übergangs an. Seit Juni 2021 werden nur noch weiche Limits unterstützt. |
delay |
Gibt eine Verzögerung an, die bei der Ausführung dieses Übergangs auftritt. Diese Verzögerung tritt immer nach dem Beenden des Quellbesuchs und vor dem Start des Zielbesuchs auf. |
Uri
Ein Universal Resource Identifier, der auf eine Ressource verweist, die von der Route Optimization API gelesen und geschrieben werden kann.
| Felder | |
|---|---|
uri |
Der URI der Ressource. Die Ressource ist möglicherweise noch nicht vorhanden. Der Inhalt der Ressource ist entweder als JSON oder als Textproto codiert. Es werden nur Google Cloud Storage-Ressourcen unterstützt. Wenn die Ressource als JSON codiert ist, muss der Ressourcennamen das Suffix |
Fahrzeug
Modelliert ein Fahrzeug bei einem Versandproblem. Wenn Sie ein Versandproblem beheben, wird für dieses Fahrzeug eine Route von start_location nach end_location erstellt. Eine Route ist eine Folge von Besuchen (siehe ShipmentRoute).
| Felder | |
|---|---|
display_name |
Der benutzerdefinierte Anzeigename des Fahrzeugs. Sie kann bis zu 63 Zeichen lang sein und UTF-8-Zeichen enthalten. |
travel_mode |
Der Reisemodus, der sich auf die für das Fahrzeug nutzbaren Straßen und seine Geschwindigkeit auswirkt. Siehe auch |
route_modifiers |
Eine Reihe von Bedingungen, die erfüllt sein müssen und sich auf die Berechnung von Routen für das jeweilige Fahrzeug auswirken. |
start_location |
Geografischer Standort, an dem das Fahrzeug vor der Abholung von Sendungen startet. Wenn nicht angegeben, beginnt die Fahrt am ersten Abholort des Fahrzeugs. Wenn das Versandmodell Dauer- und Distanzmatrizen enthält, darf |
start_waypoint |
Wegpunkt, der einen geografischen Ort darstellt, an dem das Fahrzeug vor der Abholung von Sendungen startet. Wenn weder |
end_location |
Geografischer Ort, an dem das Fahrzeug nach Abschluss der letzten |
end_waypoint |
Wegpunkt, der einen geografischen Ort darstellt, an dem das Fahrzeug nach Abschluss der letzten |
start_tags[] |
Gibt Tags an, die dem Start der Route des Fahrzeugs zugeordnet sind. Leere oder doppelte Strings sind nicht zulässig. |
end_tags[] |
Gibt Tags an, die am Ende der Route des Fahrzeugs angehängt werden. Leere oder doppelte Strings sind nicht zulässig. |
start_time_windows[] |
Zeitfenster, in denen das Fahrzeug vom Startort abfahren darf. Sie müssen innerhalb der globalen Zeitlimits liegen (siehe Zeiträume, die zum selben wiederholten Feld gehören, dürfen sich nicht überschneiden oder aneinandergrenzen und müssen in chronologischer Reihenfolge angegeben werden.
|
end_time_windows[] |
Zeitfenster, in denen das Fahrzeug am Zielort eintreffen kann. Sie müssen innerhalb der globalen Zeitlimits liegen (siehe Zeiträume, die zum selben wiederholten Feld gehören, dürfen sich nicht überschneiden oder aneinandergrenzen und müssen in chronologischer Reihenfolge angegeben werden.
|
unloading_policy |
Die Richtlinie zum Entladen wird auf das Fahrzeug angewendet. |
load_limits |
Kapazitäten des Fahrzeugs (z. B. Gewicht, Volumen, Anzahl der Paletten). Die Schlüssel in der Karte sind die Kennungen des Lasttyps, die mit den Schlüsseln des Felds |
cost_per_hour |
Fahrzeugkosten: Alle Kosten werden addiert und müssen in derselben Einheit wie Kosten pro Stunde der Fahrzeugroute. Diese Kosten werden auf die Gesamtzeit der Route angewendet und umfassen Fahrzeit, Wartezeit und Besuchszeit. Die Verwendung von |
cost_per_traveled_hour |
Kosten pro gefahrener Stunde der Fahrzeugroute. Diese Kosten werden nur auf die Reisezeit der Route angewendet (d. h. auf die in |
cost_per_kilometer |
Kosten pro Kilometer der Fahrzeugroute. Diese Kosten werden auf die in |
fixed_cost |
Feste Kosten, die anfallen, wenn dieses Fahrzeug für den Transport einer Sendung verwendet wird. |
used_if_route_is_empty |
Dieses Feld gilt nur für Fahrzeuge, deren Route keine Lieferungen umfasst. Gibt an, ob das Fahrzeug in diesem Fall als gebraucht betrachtet werden soll. Wenn „true“ festgelegt ist, fährt das Fahrzeug von seinem Start- zum Zielort, auch wenn es keine Sendungen transportiert. Zeit- und Entfernungskosten, die sich aus der Fahrt vom Start- zum Zielort ergeben, werden berücksichtigt. Andernfalls fährt es nicht von seinem Start- zum Zielort und es sind keine |
route_duration_limit |
Limit für die Gesamtdauer der Route des Fahrzeugs. In einem bestimmten |
travel_duration_limit |
Beschränkung der Reisedauer der Fahrzeugroute. In einem bestimmten |
route_distance_limit |
Limit für die Gesamtstrecke der Fahrzeugroute. In einem bestimmten |
extra_visit_duration_for_visit_type |
Gibt eine Zuordnung von visit_types-Strings zu Zeiträumen an. Die Dauer ist die Zeit zusätzlich zu Wenn eine Besichtigung mehrere Typen hat, wird für jeden Typ eine Dauer auf der Karte hinzugefügt. |
break_rule |
Beschreibt den Pausenplan, der für dieses Fahrzeug erzwungen werden soll. Wenn das Feld leer ist, werden für dieses Fahrzeug keine Pausen eingeplant. |
label |
Gibt ein Label für dieses Fahrzeug an. Dieses Label wird in der Antwort als |
ignore |
Wenn „true“ angegeben ist, muss Wenn eine Lieferung von einem ignorierten Fahrzeug in Wenn eine Sendung mit einem ignorierten Fahrzeug in |
travel_duration_multiple |
Gibt einen multiplikativen Faktor an, mit dem die Fahrzeiten dieses Fahrzeugs verlängert oder verkürzt werden können. Wenn Sie diesen Wert beispielsweise auf 2,0 festlegen, ist das Fahrzeug langsamer und die Fahrzeiten sind doppelt so lang wie bei Standardfahrzeugen. Dieser Faktor hat keine Auswirkungen auf die Besuchszeiten. Es wirkt sich auf die Kosten aus, wenn ACHTUNG: Reisezeiten werden nach Anwendung dieses Vielfachen, aber vor allen numerischen Operationen auf die nächste Sekunde gerundet. Ein kleines Vielfaches kann daher zu einem Genauigkeitsverlust führen. Siehe auch |
DurationLimit
Ein Grenzwert, der die maximale Dauer der Route eines Fahrzeugs definiert. Sie kann entweder hart oder weich sein.
Wenn ein Feld für ein weiches Limit definiert ist, müssen sowohl der Grenzwert für das weiche Maximum als auch die zugehörigen Kosten zusammen definiert werden.
| Felder | |
|---|---|
max_duration |
Ein hartes Limit, das die Dauer auf maximal max_duration begrenzt. |
soft_max_duration |
Ein weiches Limit, das keine maximale Dauer erzwingt, aber bei Überschreitung Kosten für die Route verursacht. Diese Kosten werden zu anderen Kosten addiert, die im Modell definiert sind und dieselbe Einheit haben. Falls definiert, muss |
quadratic_soft_max_duration |
Ein weiches Limit, das keine maximale Dauer erzwingt, aber bei Überschreitung Kosten für die Route verursacht, die quadratisch mit der Dauer steigen. Diese Kosten werden zu anderen Kosten addiert, die im Modell definiert sind und dieselbe Einheit haben. Falls definiert, muss
|
cost_per_hour_after_soft_max |
Kosten pro Stunde, die anfallen, wenn der Die Kosten dürfen nicht negativ sein. |
cost_per_square_hour_after_quadratic_soft_max |
Kosten pro Quadratstunde, die anfallen, wenn der Die zusätzlichen Kosten betragen 0, wenn die Dauer unter dem Schwellenwert liegt. Andernfalls hängen die Kosten wie folgt von der Dauer ab: Die Kosten dürfen nicht negativ sein. |
LoadLimit
Definiert ein Ladungsgewichtslimit für ein Fahrzeug, z. B. „Dieser Lkw darf nur bis zu 3.500 kg transportieren“. load_limits ansehen.
| Felder | |
|---|---|
soft_max_load |
Ein weiches Limit für die Last. |
cost_per_unit_above_soft_max |
Wenn die Last auf der Route dieses Fahrzeugs jemals |
start_load_interval |
Das zulässige Ladeintervall des Fahrzeugs zu Beginn der Route. |
end_load_interval |
Das zulässige Ladeintervall des Fahrzeugs am Ende der Route. |
max_load |
Die maximal zulässige Belastung. |
cost_per_kilometer |
Kosten für den Transport einer Ladeeinheit über einen Kilometer mit diesem Fahrzeug. Dies kann als Proxy für den Kraftstoffverbrauch verwendet werden: Wenn die Last ein Gewicht (in Newton) ist, hat „Last × Kilometer“ die Dimension einer Energie. Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/load-cost/make-request. |
cost_per_traveled_hour |
Kosten für die Beförderung einer Ladeeinheit mit diesem Fahrzeug für eine Stunde. Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/load-cost/make-request. |
Intervall
Intervall der zulässigen Ladebeträge.
| Felder | |
|---|---|
min |
Eine Mindestlast. Muss ≥ 0 sein. Wenn beide angegeben sind, muss |
max |
Eine maximal zulässige Belastung. Muss ≥ 0 sein. Wenn keine Angabe erfolgt, ist die maximale Belastung durch diese Meldung nicht eingeschränkt. Wenn beide angegeben sind, muss |
LoadCost
Kosten für die Verlagerung einer Lasteinheit während eines Transition. Die Kosten für eine bestimmte Last setzen sich aus zwei Teilen zusammen:
- min(load,
load_threshold) *cost_per_unit_below_threshold - max(0, load –
load_threshold) *cost_per_unit_above_threshold
Bei diesen Kosten werden Lösungen bevorzugt, bei denen zuerst hohe Anforderungen erfüllt werden oder hohe Anforderungen zuletzt abgeholt werden. Wenn ein Fahrzeug beispielsweise
load_limit {
key: "weight"
value {
cost_per_kilometer {
load_threshold: 15
cost_per_unit_below_threshold: 2.0
cost_per_unit_above_threshold: 10.0
}
}
}
Die Route ist: Start,Abholung,Abholung,Lieferung,Lieferung,Ende. Die Übergänge sind:
transition { vehicle_load['weight'] { amount: 0 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 10 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 20 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 10 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 0 }
travel_distance_meters: 1000.0 }
dann sind die Kosten für diese LoadCost (cost_below * load_below * kilometers + cost_above * load_above * kms).
- Übergang 0: 0,0
- Übergang 1: 2,0 × 10 × 1,0 + 10,0 × 0 × 1,0 = 20,0
- Übergang 2: 2,0 × 15 × 1,0 + 10,0 × (20 – 15) × 1,0 = 80,0
- Übergang 3: 2,0 × 10 × 1,0 + 10,0 × 0 × 1,0 = 20,0
- Übergang 4: 0,0
Der LoadCost für die Route beträgt also 120,0.
Wenn die Route jedoch mit Übergängen beginnt und endet, z. B. „Start,Abholung,Zustellung,Abholung,Zustellung,Ende“:
transition { vehicle_load['weight'] { amount: 0 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 10 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 0 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 10 }
travel_distance_meters: 1000.0 }
transition { vehicle_load['weight'] { amount: 0 }
travel_distance_meters: 1000.0 }
dann sind die Kosten für diese LoadCost
- Übergang 0: 0,0
- Übergang 1: 2,0 × 10 × 1,0 + 10,0 × 0 × 1,0 = 20,0
- Übergang 2: 0,0
- Übergang 3: 2,0 × 10 × 1,0 + 10,0 × 0 × 1,0 = 20,0
- Übergang 4: 0,0
Hier beträgt der LoadCost für die Route 40,0.
LoadCost macht Lösungen mit stark ausgelasteten Übergängen teurer.
Experimentell: Weitere Informationen finden Sie unter https://developers.google.com/maps/tt/route-optimization/experimental/load-cost/make-request.
| Felder | |
|---|---|
load_threshold |
Die Menge der Last, ab der sich die Kosten für die Verlagerung einer Lasteinheit von „cost_per_unit_below_threshold“ zu „cost_per_unit_above_threshold“ ändern. Muss >= 0 sein. |
cost_per_unit_below_threshold |
Die Kosten für das Verschieben einer Lasteinheit für jede Einheit zwischen 0 und dem Schwellenwert. Muss ein endlicher Wert und >= 0 sein. |
cost_per_unit_above_threshold |
Kosten für die Verlagerung einer Lasteinheit für jede Einheit über dem Schwellenwert. Im Sonderfall „Grenzwert = 0“ handelt es sich um einen Fixkostenbetrag pro Einheit. Muss ein endlicher Wert und >= 0 sein. |
TravelMode
Mobilitätsformen, die von Fahrzeugen genutzt werden können.
Dies sollte eine Teilmenge der Google Maps Platform Routes API-Fortbewegungsmittel sein. Weitere Informationen finden Sie unter https://developers.google.com/maps/documentation/routes/reference/rest/v2/RouteTravelMode.
Hinweis: WALKING-Routen befinden sich in der Betaphase und enthalten möglicherweise nicht immer ausgewiesene Fußgängerwege. Sie müssen diese Warnung für alle Fußgängerrouten, die Sie in Ihrer App anzeigen, für den Nutzer einblenden.
| Enums | |
|---|---|
TRAVEL_MODE_UNSPECIFIED |
Nicht angegebene Mobilitätsform, entspricht DRIVING. |
DRIVING |
Mobilitätsform, die der Wegbeschreibung entspricht (Auto usw.). |
WALKING |
Mobilitätsform für die Wegbeschreibung für Fußgänger. |
UnloadingPolicy
Richtlinie zum Entladen eines Fahrzeugs. Gilt nur für Sendungen mit Abholung und Zustellung.
Andere Sendungen können unabhängig von unloading_policy überall auf der Route erfolgen.
| Enums | |
|---|---|
UNLOADING_POLICY_UNSPECIFIED |
Keine Angaben zur Entladung; Lieferungen müssen nur nach den entsprechenden Abholungen erfolgen. |
LAST_IN_FIRST_OUT |
Lieferungen müssen in umgekehrter Reihenfolge der Abholungen erfolgen |
FIRST_IN_FIRST_OUT |
Lieferungen müssen in derselben Reihenfolge wie Abholungen erfolgen |
VehicleFullness
VehicleFullness ist ein Messwert, der angibt, wie voll ein Fahrzeug ist. Jeder VehicleFullness-Wert liegt zwischen 0 und 1 und wird als Verhältnis zwischen einem Messwertfeld mit Obergrenze (z.B. AggregatedMetrics.travel_distance_meters) und dem zugehörigen Fahrzeuglimit (z.B. Vehicle.route_distance_limit) berechnet, sofern es vorhanden ist. Andernfalls bleibt das Füllverhältnis nicht festgelegt. Wenn das Limit 0 ist, wird das Feld auf 1 gesetzt. Hinweis: Wenn eine Route aufgrund von Verkehrsbedingungen nicht durchführbar ist, können einige Rohwerte für das Füllverhältnis 1,0 überschreiten, z. B. wenn das Fahrzeug das Distanzlimit überschreitet. In diesen Fällen begrenzen wir die Füllwerte auf 1, 0.
| Felder | |
|---|---|
max_fullness |
Maximum aller anderen Felder in dieser Nachricht. |
distance |
Das Verhältnis zwischen |
travel_duration |
Das Verhältnis zwischen [AggregatedMetrics.travel_duration_seconds][] und |
active_duration |
Das Verhältnis zwischen [AggregatedMetrics.total_duration_seconds][] und |
max_load |
Das maximale Verhältnis zwischen allen Arten von [AggregatedMetrics.max_load][] und den entsprechenden |
active_span |
Das Verhältnis (vehicle_end_time – vehicle_start_time) / (latest_vehicle_end_time – earliest_vehicle_start_time) für ein bestimmtes Fahrzeug. Wenn der Nenner nicht vorhanden ist, wird stattdessen ( |
Zwischenstopp
Kapselt einen Wegpunkt. Wegpunkte markieren Ankunfts- und Abfahrtsorte von VisitRequests sowie Start- und Endorte von Fahrzeugen.
| Felder | |
|---|---|
side_of_road |
Optional. Gibt an, dass das Fahrzeug an einer bestimmten Straßenseite anhalten soll. Wenn Sie diesen Wert festlegen, verläuft die Route durch den Ort, sodass das Fahrzeug am Straßenrand anhalten kann, der vom Straßenmittelpunkt aus in Richtung des Ortes liegt. Diese Option funktioniert nicht für die Mobilitätsform „WALKING“. |
vehicle_stopover |
Gibt an, dass der Wegpunkt für Fahrzeuge vorgesehen ist, an denen sie anhalten sollen, um Personen abzuholen oder abzusetzen. Diese Option funktioniert nur für den Fortbewegungsmittelmodus „DRIVING“ und wenn „location_type“ auf „location“ festgelegt ist. Testphase: Das Verhalten oder die Existenz dieses Felds kann sich in Zukunft ändern. |
Union-Feld location_type. Verschiedene Möglichkeiten, einen Ort darzustellen. Für location_type ist nur einer der folgenden Werte zulässig: |
|
location |
Ein Punkt, der mit geografischen Koordinaten angegeben wird, einschließlich einer optionalen Richtung. |
place_id |
Die POI-Orts-ID, die mit dem Wegpunkt verknüpft ist. Wenn Sie eine Orts-ID verwenden, um den Ankunfts- oder Abfahrtsort einer VisitRequest anzugeben, muss die Orts-ID so spezifisch sein, dass ein LatLng-Standort für die Navigation zum Ort bestimmt werden kann. Eine Orts-ID, die ein Gebäude darstellt, ist beispielsweise geeignet, eine Orts-ID, die eine Straße darstellt, jedoch nicht. |