- JSON gösterimi
- Gönderim
- VisitRequest
- LatLng
- Waypoint
- Konum
- TimeWindow
- Araç
- TravelMode
- UnloadingPolicy
- LoadLimit
- Aralık
- DurationLimit
- DistanceLimit
- BreakRule
- BreakRequest
- FrequencyConstraint
- DurationDistanceMatrix
- Satır
- TransitionAttributes
- ShipmentTypeIncompatibility
- IncompatibilityMode
- ShipmentTypeRequirement
- RequirementMode
- PrecedenceRule
Gönderim modeli, bir grup araç tarafından gerçekleştirilmesi gereken bir dizi gönderim içerir ve toplam maliyeti en aza indirir. Bu durumda toplam maliyet, toplamda şu olur:
- Araç rotalarının maliyeti (toplam süre başına maliyet, seyahat süresi başına maliyet ve tüm araçlar için sabit maliyetin toplamı).
- yapılmayan kargo cezaları.
- Global sevkiyat süresinin maliyeti
JSON gösterimi |
---|
{ "shipments": [ { object ( |
Alanlar | |
---|---|
shipments[] |
Modelde yapılması gereken kargolar grubu. |
vehicles[] |
Ziyaret yapmak için kullanılabilecek araç grubu. |
globalStartTime |
Modelin genel başlangıç ve bitiş zamanı: Bu aralık dışındaki hiçbir zaman geçerli kabul edilemez. Modelin zaman aralığı bir yıldan kısa olmalıdır. Yani
RFC3339 UTC "Zulu" biçiminde, nanosaniye çözünürlüğüne ve en fazla dokuz kesirli basamağa sahip bir zaman damgası. Örnekler: |
globalEndTime |
Ayarlanmadan bırakılırsa 1 Ocak 1971, 00:00:00 UTC (yani saniye: 31536000, nanos: 0) varsayılan olarak kullanılır. Nanosaniye çözünürlüğüne sahip ve en fazla dokuz kesirli basamak içeren RFC3339 UTC "Zulu" biçiminde bir zaman damgası. Örnekler: |
globalDurationCostPerHour |
Genel planın "küresel süresi", tüm araçların en erken geçerli başlangıç zamanı ile en geç geçerli bitiş zamanı arasındaki farktır. Kullanıcılar, örneğin en kısa sürede iş tamamlama için optimizasyon yapmaya çalışmak üzere bu miktara saat başına bir maliyet atayabilir. Bu maliyet, |
durationDistanceMatrices[] |
Modelde kullanılan süre ve mesafe matrislerini belirtir. Bu alan boşsa Kullanım örnekleri:
|
durationDistanceMatrixSrcTags[] |
Süre ve mesafe matrislerinin kaynaklarını tanımlayan etiketler; Etiketler |
durationDistanceMatrixDstTags[] |
Süre ve mesafe matrislerinin hedeflerini tanımlayan etiketler; Etiketler |
transitionAttributes[] |
Modele geçiş özellikleri eklendi. |
shipmentTypeIncompatibilities[] |
Uyumsuz shipment_types grupları ( |
shipmentTypeRequirements[] |
|
precedenceRules[] |
Modelde uygulanması gereken öncelik kuralları kümesi. |
maxActiveVehicles |
Maksimum etkin araç sayısını kısıtlar. Rotasında en az bir gönderim yapılan araçlar etkindir. Bu, sürücü sayısının araç sayısından az olduğu ve araç filosunun heterojen olduğu durumlarda rota sayısını sınırlamak için kullanılabilir. Ardından optimizasyon, kullanılacak en iyi araç alt kümesini seçer. Tamamen olumlu olmalıdır. |
Gönderim
Tek bir öğenin, teslim alma alanlarından birinden teslimatlarına kadar gönderilmesi. Gönderimin gerçekleştirilmiş olarak kabul edilmesi için benzersiz bir aracın, teslim alma konumlarından birini ziyaret etmesi (ve yedek kapasitelerini buna göre azaltması) ve daha sonra teslimat konumlarından birini ziyaret etmesi (ve yedek kapasitelerini buna göre yeniden artırması) gerekir.
JSON gösterimi |
---|
{ "displayName": string, "pickups": [ { object ( |
Alanlar | |
---|---|
displayName |
Gönderinin kullanıcı tanımlı görünen adı. En fazla 63 karakter uzunluğunda olabilir ve UTF-8 karakterleri kullanabilir. |
pickups[] |
Kargoyla ilişkili teslim alma alternatifleri grubu. Belirtilmemişse aracın yalnızca teslimatlara karşılık gelen bir konumu ziyaret etmesi gerekir. |
deliveries[] |
Kargoyla ilişkili teslimat alternatifleri grubu. Belirtilmemişse aracın yalnızca teslim alma noktalarına karşılık gelen bir konumu ziyaret etmesi gerekir. |
loadDemands |
Gönderinin yükleme talepleri (ör. ağırlık, hacim, palet sayısı vb.). Haritadaki anahtarlar, ilgili yükün türünü açıklayan tanımlayıcılardır (ideal olarak birimleri de içermelidir). Örneğin: "weight_kg", "quantity_galon", "pallet_count" vb. Belirli bir anahtar haritada görünmezse karşılık gelen yükleme null olarak kabul edilir.
|
allowedVehicleIndices[] |
Bu sevkiyatı gerçekleştirebilecek araç grubu. Boşsa tüm araçlar bu işlemi gerçekleştirebilir. Araçlar, |
costsPerVehicle[] |
Bu gönderim her araç tarafından teslim edildiğinde ortaya çıkan maliyeti belirtir. Belirtilmişse ŞUNLARDAN BİRİNİ içermelidir:
Bu maliyetler |
costsPerVehicleIndices[] |
|
pickupToDeliveryAbsoluteDetourLimit |
Alınma noktasından teslimat noktasına giden en kısa yola kıyasla maksimum mutlak ek süreyi belirtir. Belirtilmişse negatif olmamalıdır ve kargo en azından bir teslim alma ve teslimat içermelidir. Örneğin, t, seçilen teslim alma alternatifinden doğrudan seçilen teslimat alternatifine gitmek için gereken en kısa süre olsun. Ardından
Aynı gönderimde hem göreli hem de mutlak sınırlar belirtilirse olası her teslim alma/teslimat çifti için daha kısıtlayıcı sınır kullanılır. 2017/10 tarihi itibarıyla, yalnızca seyahat süreleri araçlara bağlı olmadığında rota değişikliği desteklenmektedir. En fazla dokuz kesirli basamak içeren ve " |
pickupToDeliveryTimeLimit |
Bir gönderinin teslim alınma başlangıcından teslimat başlangıcına kadar geçen maksimum süreyi belirtir. Belirtiliyse pozitif olmalıdır ve gönderim en az bir teslim alma ve teslimat içermelidir. Bu, teslim alma ve teslimat için seçilen alternatiflere veya aracın hızına bağlı değildir. Bu, maksimum sapma kısıtlamalarıyla birlikte belirtilebilir: Çözüm her iki spesifikasyona da uyar. " |
shipmentType |
Bu gönderim için "tür" belirten boş olmayan dize. Bu özellik, Tek bir ziyaret için belirtilen |
label |
Bu gönderim için bir etiket belirtir. Bu etiket, yanıtta ilgili |
ignore |
True (doğru) ise bu kargoyu atlayın, ancak Modelde
|
penaltyCost |
Gönderim tamamlanmazsa bu ceza, rotaların toplam maliyetine eklenir. Teslim alma ve teslimat alternatiflerinden birinin ziyaret edilmesi durumunda kargo tamamlanmış olarak kabul edilir. Maliyet, modeldeki diğer tüm maliyetle ilgili alanlar için kullanılan birimle ifade edilebilir ve pozitif olmalıdır. ÖNEMLİ: Bu ceza belirtilmezse sonsuz olarak kabul edilir, yani gönderimin tamamlanması gerekir. |
pickupToDeliveryRelativeDetourLimit |
Alıştan teslimata kadar olan en kısa yola kıyasla maksimum göreli ek süreyi belirtir. Belirtiliyse pozitif olmalıdır ve gönderim en az bir teslim alma ve teslimat içermelidir. Örneğin, t, seçilen teslim alma alternatifinden doğrudan seçilen teslimat alternatifine gitmek için gereken en kısa süre olsun. Ardından
Aynı gönderimde hem göreli hem de mutlak sınırlar belirtilirse olası her teslim alma/teslimat çifti için daha kısıtlayıcı sınır kullanılır. 2017/10 tarihi itibarıyla, yalnızca seyahat süreleri araçlara bağlı olmadığında rota değişikliği desteklenmektedir. |
VisitRequest
Araç tarafından yapılabilecek bir ziyaret isteği: Aracın coğrafi konumu (veya iki tanesi aşağıya bakın), zaman aralıklarıyla gösterilen açılış ve kapanış zamanları ve hizmet süresi (ürünlerin teslim alınması veya teslim edilmesi için vardığı araç tarafından harcanan süre) belirtilmelidir.
JSON gösterimi |
---|
{ "arrivalLocation": { object ( |
Alanlar | |
---|---|
arrivalLocation |
Bu |
arrivalWaypoint |
Bu |
departureLocation |
Bu |
departureWaypoint |
Bu |
tags[] |
Ziyaret isteğine eklenen etiketleri belirtir. Boş veya yinelenen dizelere izin verilmez. |
timeWindows[] |
Ziyarete varış saatini sınırlayan zaman aralıkları. Bir aracın, varış zamanı aralığının dışında hareket edebileceğini unutmayın. Yani varış zamanı + sürenin bir zaman aralığında olması gerekmez. Araç
Zaman aralıkları birbirinden ayrı olmalıdır. Yani hiçbir zaman aralığı diğeriyle örtüşmemeli veya bitişik olmamalıdır. Ayrıca zaman aralıkları artan düzende olmalıdır.
|
duration |
Ziyaretin süresi, yani aracın varış ile ayrılış arasında geçirdiği süre (olası bekleme süresine eklenir; " |
cost |
Bu ziyaret isteğini bir araç rotasında yerine getirmenin maliyeti. Bu değer, bir gönderinin her alternatif teslim alma veya teslimat seçeneği için farklı maliyetler ödemek amacıyla kullanılabilir. Bu maliyet, |
loadDemands |
Bu ziyaret isteğinin isteklerini yükleyin. Bu,
|
visitTypes[] |
Ziyaretin türlerini belirtir. Bu, bir aracın bu ziyareti tamamlaması için gereken ek süreyi tahsis etmek amacıyla kullanılabilir ( Bir tür yalnızca bir kez görünebilir. |
label |
Bu |
avoidUTurns |
Bu konumdaki sürüş rotalarında U dönüşü yapılmasının engellenip engellenmeyeceğini belirtir. U dönüşü olan kaçınma en iyi seçenektir ve tamamen kaçınılması garanti edilmez. Bu deneysel bir özelliktir ve davranışında değişiklik yapılabilir. |
LatLng
Enlem/boylam çiftini temsil eden bir nesne. Bu değer, enlem derecelerini ve boylam derecelerini temsil eden bir çift çift olarak ifade edilir. Aksi belirtilmediği sürece bu nesne WGS84 standardına uygun olmalıdır. Değerler normalleştirilmiş aralıklar içinde olmalıdır.
JSON gösterimi |
---|
{ "latitude": number, "longitude": number } |
Alanlar | |
---|---|
latitude |
Derece cinsinden enlem. [-90,0, +90,0] aralığında olmalıdır. |
longitude |
Derece cinsinden boylam. [-180,0; +180,0] aralığında olmalıdır. |
Ara nokta
Bir ara noktayı kapsüller. Referans noktaları, Ziyaret İstekleri'nin varış ve kalkış konumları ile Araçların başlangıç ve bitiş konumlarını gösterir.
JSON gösterimi |
---|
{ "sideOfRoad": boolean, // Union field |
Alanlar | |
---|---|
sideOfRoad |
İsteğe bağlı. Bu yol işaretinin konumunun, aracın yolun belirli bir tarafında durması için tercih edildiğini belirtir. Bu değeri ayarladığınızda rota, konumdan geçer. Böylece araç, konumun merkezine göre ağırlık verdiği yol kenarında durabilir. Bu seçenek "HAYIR" ulaşım modunda kullanılamaz. |
Birlik alanı location_type . Bir konumu temsil etmenin farklı yolları. location_type şunlardan yalnızca biri olabilir: |
|
location |
İsteğe bağlı bir başlık da dahil olmak üzere, coğrafi koordinatlar kullanılarak belirtilen bir nokta. |
placeId |
Dönüm noktasıyla ilişkili ÖY yer kimliği. |
Konum
Bir konumu (coğrafi nokta ve isteğe bağlı başlık) kapsar.
JSON gösterimi |
---|
{
"latLng": {
object ( |
Alanlar | |
---|---|
latLng |
Yol noktasının coğrafi koordinatları. |
heading |
Trafik akışının yönüyle ilişkili pusula istikameti. Bu değer, teslim alma ve bırakma için kullanılacak yolun kenarını belirtmek için kullanılır. Başlık değerleri 0 ile 360 arasında olabilir. 0 değeri Kuzey yönüne, 90 ise teslim edilecek Doğu başlığını vb. belirtir. |
TimeWindow
Zaman aralıkları, ziyaretin varış saati veya bir aracın başlangıç ve bitiş zamanı gibi bir etkinliğin zamanını kısıtlar.
startTime
ve endTime
sabit zaman aralığı sınırları, etkinliğin en erken ve en geç zamanını (startTime <= event_time <=
endTime
) uygular. Yumuşak zaman aralığı alt sınırı softStartTime
, etkinliğin softStartTime'dan ne kadar süre önce gerçekleştiğiyle orantılı bir maliyete neden olarak etkinliğin softStartTime
'te veya sonrasında gerçekleşmesi tercihini ifade eder. Geçici zaman aralığı üst sınırı (softEndTime
), etkinliğin gerçekleşmesinden softEndTime
sonra ne kadar süreyle orantılı bir maliyet oluşturarak etkinliğin softEndTime
tarihinde veya öncesinde gerçekleşmesi tercihini ifade eder. startTime
, endTime
, softStartTime
ve softEndTime
, genel zaman sınırlarına (ShipmentModel.global_start_time
ve ShipmentModel.global_end_time
'e bakın) uymalı ve aşağıdakilere dikkat etmelidir:
0 <= `startTime` <= `endTime` and
0 <= `startTime` <= `softStartTime` and
0 <= `softEndTime` <= `endTime`.
JSON gösterimi |
---|
{ "startTime": string, "endTime": string, "softStartTime": string, "softEndTime": string, "costPerHourBeforeSoftStartTime": number, "costPerHourAfterSoftEndTime": number } |
Alanlar | |
---|---|
startTime |
Zorunlu zaman aralığının başlangıç zamanı. Belirtilmemesi durumunda Nanosaniye çözünürlüğüne sahip ve en fazla dokuz kesirli basamak içeren RFC3339 UTC "Zulu" biçiminde bir zaman damgası. Örnekler: |
endTime |
Zor zaman aralığı bitiş zamanı. Belirtilmemişse RFC3339 UTC "Zulu" biçiminde, nanosaniye çözünürlüğüne ve en fazla dokuz kesirli basamağa sahip bir zaman damgası. Örnekler: |
softStartTime |
Zaman aralığının yumuşak başlangıç zamanı. Nanosaniye çözünürlüğüne sahip ve en fazla dokuz kesirli basamak içeren RFC3339 UTC "Zulu" biçiminde bir zaman damgası. Örnekler: |
softEndTime |
Zaman aralığının geçici bitiş zamanı. Nanosaniye çözünürlüğüne sahip ve en fazla dokuz kesirli basamak içeren RFC3339 UTC "Zulu" biçiminde bir zaman damgası. Örnekler: |
costPerHourBeforeSoftStartTime |
Etkinlik softStartTime'dan önce gerçekleşirse modeldeki diğer maliyetlere eklenen saat başına maliyet. Şu şekilde hesaplanır:
Bu maliyet pozitif olmalıdır ve alan yalnızca softStartTime ayarlanmışsa ayarlanabilir. |
costPerHourAfterSoftEndTime |
Etkinlik
Bu maliyet pozitif olmalıdır ve alan yalnızca |
Araç
Gönderim sorunu olan bir aracı modeller. Bir gönderim sorununun çözülmesi, bu araç için startLocation
ile endLocation
arasında bir rota oluşturur. Rota, ziyaretlerden oluşan bir sıradır (ShipmentRoute
bölümüne bakın).
JSON gösterimi |
---|
{ "displayName": string, "travelMode": enum ( |
Alanlar | |
---|---|
displayName |
Aracın kullanıcı tarafından tanımlanan görünen adı. 63 karaktere kadar uzun olabilir ve UTF-8 karakterleri içerebilir. |
travelMode |
Aracın kullanabileceği yolları ve hızını etkileyen ulaşım şekli. Ayrıca bkz. |
startLocation |
Araç, kargoyu teslim almaya başlamadan önce hangi coğrafi konumdadır? Belirtilmemişse araç ilk teslimatında başlar. Gönderim modelinin süre ve mesafe matrisleri varsa |
startWaypoint |
Aracın herhangi bir kargoyu teslim almadan önce başladığı coğrafi konumu temsil eden yol noktası. |
endLocation |
Aracın son |
endWaypoint |
Aracın son |
startTags[] |
Aracın rotasının başlangıcına eklenen etiketleri belirtir. Boş veya yinelenen dizelere izin verilmez. |
endTags[] |
Aracın rotasının sonuna eklenen etiketleri belirtir. Boş veya yinelenen dizelere izin verilmez. |
startTimeWindows[] |
Aracın başlangıç konumundan ayrılabileceği zaman aralıkları. Bu değerler, genel zaman sınırları içinde olmalıdır ( Aynı tekrarlanan alana ait zaman aralıkları birbirinden ayrı olmalıdır. Yani hiçbir zaman aralığı başka bir zaman aralığıyla çakışamaz veya başka bir zaman aralığına bitişik olamaz. Ayrıca zaman aralıkları kronolojik sırayla olmalıdır.
|
endTimeWindows[] |
Aracın bitiş konumuna ulaşabileceği zaman aralıkları. Bu değerler, genel zaman sınırları içinde olmalıdır ( Aynı tekrarlanan alana ait zaman aralıkları birbirinden ayrı olmalıdır. Yani hiçbir zaman aralığı başka bir zaman aralığıyla çakışamaz veya başka bir zaman aralığına bitişik olamaz. Ayrıca zaman aralıkları kronolojik sırayla olmalıdır.
|
unloadingPolicy |
Araçta uygulanan kaldırma politikası. |
loadLimits |
Aracın kapasiteleri (ör. ağırlık, hacim, palet sayısı). Haritadaki anahtarlar,
|
costPerHour |
Araç maliyetleri: Tüm maliyetler toplanır ve Araç rotasının saatlik maliyeti. Bu maliyet, rotanın toplam süresine uygulanır ve seyahat süresi, bekleme süresi ve ziyaret süresini içerir. Yalnızca |
costPerTraveledHour |
Araç rotasının kat edilen her saati başına maliyet. Bu maliyet yalnızca rotanın aldığı seyahat süresine (yani |
costPerKilometer |
Araç rotasının kilometre başına maliyeti. Bu maliyet, |
fixedCost |
Bu araç bir gönderimi yönetmek için kullanılıyorsa sabit maliyet uygulanır. |
usedIfRouteIsEmpty |
Bu alan yalnızca rotalarında kargo hizmeti verilmeyen araçlar için geçerlidir. Bu durumda aracın kullanılmış olarak kabul edilip edilmeyeceğini belirtir. Doğru ise araç, herhangi bir gönderi sunmasa bile başlangıç konumundan bitiş konumuna gider ve başlangıç ile bitiş arasındaki seyahat nedeniyle oluşan zaman ve mesafe maliyetleri dikkate alınır. Aksi takdirde, başlangıç konumundan bitiş konumuna gitmez ve bu araç için |
routeDurationLimit |
Aracın rotasının toplam süresi için uygulanan sınır. Belirli bir |
travelDurationLimit |
Aracın rotasının seyahat süresine uygulanan sınır. Belirli bir |
routeDistanceLimit |
Aracın rotasının toplam mesafesine uygulanan sınır. Belirli bir |
extraVisitDurationForVisitType |
visitTypes dizelerinden sürelere bir eşleme belirtir. Süre, belirtilen Bir ziyaret isteği birden fazla türdeyse haritaya her tür için bir süre eklenir.
|
breakRule |
Bu araçta uygulanacak ara programını açıklar. Boş bırakılırsa bu araç için ara verme planlanmaz. |
label |
Bu aracın etiketini belirtir. Bu etiket, yanıtta ilgili |
ignore |
Değer true ise Bir gönderim
|
travelDurationMultiple |
Bu aracın seyahat sürelerini artırmak veya azaltmak için kullanılabilen çarpım faktörünü belirtir. Örneğin, bu değeri 2,0 olarak ayarlamak, bu aracın daha yavaş olduğu ve seyahat sürelerinin standart araçlara kıyasla iki kat daha uzun olduğu anlamına gelir. Bu katsayı, ziyaret sürelerini etkilemez. UYARI: Seyahat süreleri, bu çarpan uygulandıktan sonra ancak herhangi bir sayısal işlem yapılmadan önce en yakın saniyeye yuvarlanır. Bu nedenle, küçük bir çarpan hassasiyet kaybına neden olabilir. Aşağıdaki |
TravelMode
Araçlar tarafından kullanılabilen ulaşım şekilleri.
Bunlar, Google Haritalar Platformu Routes Preferred API seyahat modlarının bir alt kümesi olmalıdır. Şu adrese göz atın: https://developers.google.com/maps/documentation/routes_preferred/reference/rest/Shared.Types/RouteTravelMode.
Sıralamalar | |
---|---|
TRAVEL_MODE_UNSPECIFIED |
Belirtilmemiş ulaşım şekli, DRIVING ile eşdeğerdir. |
DRIVING |
Arabayla yol tariflerine karşılık gelen ulaşım şekli (araba, ...). |
WALKING |
Yaya yol tarifine karşılık gelen ulaşım modu. |
UnloadingPolicy
Bir aracın nasıl boşaltılabileceğiyle ilgili politika. Yalnızca hem teslim alma hem de teslimat seçeneği bulunan gönderiler için geçerlidir.
Diğer gönderimler, unloadingPolicy
'ten bağımsız olarak rotanın herhangi bir yerinde yapılabilir.
Sıralamalar | |
---|---|
UNLOADING_POLICY_UNSPECIFIED |
Belirtilmemiş kaldırma politikası; teslimatlar, yalnızca ilgili teslim alma işlemlerinden sonra gerçekleştirilmelidir. |
LAST_IN_FIRST_OUT |
Teslimatlar, teslim alma sırası tersten yapılmalıdır |
FIRST_IN_FIRST_OUT |
Teslimatlar, teslim almalarla aynı sırada yapılmalıdır |
LoadLimit
Araç için geçerli olan yük sınırını tanımlar (ör. "bu kamyon en fazla 3500 kg taşıyabilir"). Şu sayfaya göz atın: loadLimits
.
JSON gösterimi |
---|
{ "softMaxLoad": string, "costPerUnitAboveSoftMax": number, "startLoadInterval": { object ( |
Alanlar | |
---|---|
softMaxLoad |
Yükün yumuşak sınırı. Şu sayfaya göz atın: |
costPerUnitAboveSoftMax |
Yük, bu aracın rotasında |
startLoadInterval |
Rotanın başlangıcında aracın kabul edilebilir yük aralığı. |
endLoadInterval |
Rotanın sonunda aracın kabul edilebilir yük aralığı. |
maxLoad |
Kabul edilebilir maksimum yük miktarı. |
Aralık
Kabul edilebilir yük miktarları aralığı.
JSON gösterimi |
---|
{ "min": string, "max": string } |
Alanlar | |
---|---|
min |
Kabul edilebilir minimum yük. ≥ 0 olmalıdır. İkisi de belirtilmişse |
max |
Maksimum kabul edilebilir yük. ≥ 0 olmalıdır. Belirtilmemişse maksimum yükleme bu iletiyle kısıtlanmaz. İkisi de belirtilmişse |
DurationLimit
Bir aracın rotanın maksimum süresini tanımlayan sınır. Sert veya yumuşak olabilir.
Bir esnek sınır alanı tanımlandığında, hem esnek maksimum eşiği hem de ilişkili maliyeti birlikte tanımlanmalıdır.
JSON gösterimi |
---|
{ "maxDuration": string, "softMaxDuration": string, "quadraticSoftMaxDuration": string, "costPerHourAfterSoftMax": number, "costPerSquareHourAfterQuadraticSoftMax": number } |
Alanlar | |
---|---|
maxDuration |
Süreyi en fazla maxDuration olarak kısıtlayan katı bir sınır. " |
softMaxDuration |
Maksimum süre sınırı uygulanmayan, ancak ihlal edildiğinde rotanın ücretlendirilen bir sınırı olan sabit bir sınır. Bu maliyet, modelde tanımlanan diğer maliyetlerle (aynı birimde) toplanır. Tanımlanmışsa " |
quadraticSoftMaxDuration |
Maksimum süre sınırı uygulamayan ancak ihlal edildiğinde rotanın süreye bağlı olarak karesel bir maliyete maruz kalmasına neden olan yumuşak sınır. Bu maliyet, modelde tanımlanan diğer maliyetlerle (aynı birimde) toplanır. Tanımlanmışsa
" |
costPerHourAfterSoftMax |
Maliyet negatif olmamalıdır. |
costPerSquareHourAfterQuadraticSoftMax |
Süre eşik değerinin altındaysa ek maliyet 0'dır. Aksi takdirde maliyet, süreye bağlı olarak aşağıdaki gibidir:
Maliyet pozitif olmalıdır. |
DistanceLimit
Katedilebilecek maksimum mesafeyi tanımlayan sınır. Sert veya yumuşak olabilir.
Hafif sınır tanımlanırsa hem softMaxMeters
hem de costPerKilometerAboveSoftMax
tanımlanmalı ve negatif olmayan bir sayı olmalıdır.
JSON gösterimi |
---|
{ "maxMeters": string, "softMaxMeters": string, "costPerKilometerAboveSoftMax": number } |
Alanlar | |
---|---|
maxMeters |
Mesafeyi en fazla maxMeter olacak şekilde sınırlayan kesin bir sınır. Sınır negatif olmamalıdır. |
softMaxMeters |
Maksimum mesafe sınırı uygulamayan ancak ihlal edildiğinde modelde tanımlanan diğer maliyetlerle aynı birimde toplanan bir maliyete neden olan yumuşak sınır. Tanımlanmışsa softMaxMeters'lar, maxMeters'tan küçük olmalı ve negatif olmamalıdır. |
costPerKilometerAboveSoftMax |
Mesafe
Maliyet negatif olmamalıdır. |
BreakRule
Bir araç için ara verme zamanları (ör. öğle yemeği araları) oluşturmaya yönelik kurallar. Ara, aracın mevcut konumunda boşta kaldığı ve herhangi bir ziyaret gerçekleştiremediği kesintisiz bir zaman aralığıdır. Aşağıdaki durumlarda ara verilebilir:
- iki ziyaret arasında seyahat sırasında (ziyaretten hemen önce veya hemen sonra olan süreyi içerir ancak ziyaretin ortasını kapsamaz) ziyaretler arasındaki ilgili geçiş süresini uzatır.
- veya araç çalışmaya başlamadan önce başlar (araç, aranın ortasında başlamayabilir) ve bu durumda aracın başlangıç süresi etkilenmez.
- veya araç sona erdikten sonra (araç sona erme zamanı da aynı şekilde).
JSON gösterimi |
---|
{ "breakRequests": [ { object ( |
Alanlar | |
---|---|
breakRequests[] |
Aralar dizisi. |
frequencyConstraints[] |
Birkaç |
BreakRequest
Her araç için geçerli olan ara verme sırası (ör. sayısı ve sırası) önceden bilinmelidir. Tekrarlanan BreakRequest
'ler, bu sırayı gerçekleşmeleri gereken sırayla tanımlar. Aralarındaki zaman aralıkları (earliestStartTime
/ latestStartTime
) çakışabilir ancak siparişle uyumlu olmalıdır (bu seçenek işaretlidir).
JSON gösterimi |
---|
{ "earliestStartTime": string, "latestStartTime": string, "minDuration": string } |
Alanlar | |
---|---|
earliestStartTime |
Zorunlu. Aranın başlangıcındaki alt sınır (dahil). Nanosaniye çözünürlüğüne sahip ve en fazla dokuz kesirli basamak içeren RFC3339 UTC "Zulu" biçiminde bir zaman damgası. Örnekler: |
latestStartTime |
Zorunlu. Aranın başlangıcındaki üst sınır (dahil). Nanosaniye çözünürlüğüne sahip ve en fazla dokuz kesirli basamak içeren RFC3339 UTC "Zulu" biçiminde bir zaman damgası. Örnekler: |
minDuration |
Zorunlu. Minimum ara süresi. Pozitif olmalıdır. " |
FrequencyConstraint
"12 saatte en az 1 saatlik ara verilmelidir" gibi minimum ara sıklıklarını zorunlu kılarak yukarıda belirtilen araların sıklığını ve süresini daha da kısıtlayabilirsiniz. Bunun "12 saatlik herhangi bir kayan zaman aralığında en az bir saatlik en az bir ara verilmelidir" şeklinde yorumlanabileceği varsayıldığında, bu örnek aşağıdaki FrequencyConstraint
ile çevrilir:
{
minBreakDuration { seconds: 3600 } # 1 hour.
maxInterBreakDuration { seconds: 39600 } # 11 hours (12 - 1 = 11).
}
Çözümdeki araların zamanlaması ve süresi, BreakRequest
içinde önceden belirtilen zaman aralıklarını ve minimum süreleri de dikkate alarak bu tür tüm kısıtlamalara uyar.
FrequencyConstraint
, pratikte art arda olmayan aralar için geçerli olabilir. Örneğin, aşağıdaki programda "12 saatte 1 saat" örneği dikkate alınmıştır:
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
JSON gösterimi |
---|
{ "minBreakDuration": string, "maxInterBreakDuration": string } |
Alanlar | |
---|---|
minBreakDuration |
Zorunlu. Bu kısıtlama için minimum ara süresi. Negatif değil. " |
maxInterBreakDuration |
Zorunlu. Rotada en azından kısmen En fazla dokuz kesirli basamak içeren ve " |
DurationDistanceMatrix
Ziyaret ve araç başlangıç konumlarından ziyaret ve araç bitiş konumlarına kadar bir süre ve mesafe matrisi belirtir.
JSON gösterimi |
---|
{
"rows": [
{
object ( |
Alanlar | |
---|---|
rows[] |
Süre ve mesafe matrisinin satırlarını belirtir. |
vehicleStartTag |
Bu süre ve mesafe matrisinin hangi araçlar için geçerli olduğunu tanımlayan etiket. Boşsa tüm araçlar için geçerlidir ve yalnızca tek bir matris olabilir. Her araç başlangıcı tam olarak bir matrisle eşleşmelidir. Yani Tüm matrisler farklı bir |
Satır
Süre ve mesafe matrisinin satırını belirtir.
JSON gösterimi |
---|
{ "durations": [ string ], "meters": [ number ] } |
Alanlar | |
---|---|
durations[] |
Belirli bir satırın süre değerleri. En fazla dokuz kesirli basamak içeren ve " |
meters[] |
Belirli bir satırın mesafe değerleri. Modeldeki mesafelere atıfta bulunan hiçbir maliyet veya kısıtlama yoksa bu alan boş bırakılabilir. Aksi takdirde |
TransitionAttributes
Bir rotada art arda yapılan iki ziyaret arasındaki geçişlerin özelliklerini belirtir. Aynı geçiş için birden fazla TransitionAttributes
geçerli olabilir: Bu durumda, tüm ek maliyetler toplanır ve en katı kısıtlama veya sınır uygulanır (doğal "VE" semantiğine göre).
JSON gösterimi |
---|
{
"srcTag": string,
"excludedSrcTag": string,
"dstTag": string,
"excludedDstTag": string,
"cost": number,
"costPerKilometer": number,
"distanceLimit": {
object ( |
Alanlar | |
---|---|
srcTag |
Bu özelliklerin geçerli olduğu (src->dst) geçiş grubunu tanımlayan etiketler. Bir kaynak ziyareti veya araç başlatma işlemi, |
excludedSrcTag |
Şu sayfaya göz atın: |
dstTag |
Bir hedef ziyaret veya araç sonu, |
excludedDstTag |
Şu sayfaya göz atın: |
cost |
Bu geçişi gerçekleştirmenin maliyetini belirtir. Bu değer, modeldeki diğer tüm maliyetlerle aynı birimdir ve negatif olmamalıdır. Diğer tüm mevcut maliyetlerin üzerine uygulanır. |
costPerKilometer |
Bu geçiş sırasında kat edilen mesafeye uygulanan kilometre başına maliyeti belirtir. Araçlarda belirtilen tüm |
distanceLimit |
Bu geçiş gerçekleştirilirken katedilen mesafe için bir sınırı belirtir. 06.06.2021 itibarıyla yalnızca geçici sınırlar desteklenmektedir. |
delay |
Bu geçiş gerçekleştirilirken oluşan gecikmeyi belirtir. Bu gecikme her zaman kaynak ziyareti tamamlandıktan sonra ve hedef ziyareti başlatılmadan önce gerçekleşir. En fazla dokuz kesirli basamak içeren ve " |
ShipmentTypeIncompatibility
Gönderim türlerine bağlı olarak gönderimler arasındaki uyumsuzlukları belirtir. Aynı rotadaki uyumsuz kargoların görünümü, uyumsuzluk moduna göre kısıtlanır.
JSON gösterimi |
---|
{
"types": [
string
],
"incompatibilityMode": enum ( |
Alanlar | |
---|---|
types[] |
Uyumsuz türlerin listesi. Listelenenler arasından farklı |
incompatibilityMode |
Uyumsuzluk için uygulanan mod. |
IncompatibilityMode
Aynı rotadaki uyumsuz gönderimlerin görünümünün nasıl kısıtlandığını tanımlayan modlar.
Sıralamalar | |
---|---|
INCOMPATIBILITY_MODE_UNSPECIFIED |
Belirtilmemiş uyumsuzluk modu. Bu değer hiçbir zaman kullanılmamalıdır. |
NOT_PERFORMED_BY_SAME_VEHICLE |
Bu modda, uyumsuz türlere sahip iki gönderim hiçbir zaman aynı aracı paylaşamaz. |
NOT_IN_SAME_VEHICLE_SIMULTANEOUSLY |
|
ShipmentTypeRequirement
deliveryType'a göre gönderimler arasındaki şartları belirtir. Koşulun ayrıntıları, koşul moduna göre belirlenir.
JSON gösterimi |
---|
{
"requiredShipmentTypeAlternatives": [
string
],
"dependentShipmentTypes": [
string
],
"requirementMode": enum ( |
Alanlar | |
---|---|
requiredShipmentTypeAlternatives[] |
|
dependentShipmentTypes[] |
NOT: |
requirementMode |
Mod, koşula uygulandı. |
RequirementMode
Bağımlı gönderilerin rota üzerindeki görünümünü tanımlayan modlar.
Sıralamalar | |
---|---|
REQUIREMENT_MODE_UNSPECIFIED |
Belirtilmemiş gereksinim modu. Bu değer hiçbir zaman kullanılmamalıdır. |
PERFORMED_BY_SAME_VEHICLE |
Bu modda, tüm "bağımlı" gönderiler, "zorunlu" gönderimlerinden en az biriyle aynı aracı paylaşmalıdır. |
IN_SAME_VEHICLE_AT_PICKUP_TIME |
Bu nedenle, "bağımlı" bir kargonun teslim alınması şunlardan birine sahip olmalıdır:
|
IN_SAME_VEHICLE_AT_DELIVERY_TIME |
Daha önce olduğu gibi, "bağımlı" gönderimlerin teslimat sırasında araçlarında "zorunlu" bir gönderim olması gerekir. |
PrecedenceRule
İki etkinlik arasındaki öncelik kuralı (her etkinlik, bir gönderinin teslim alınması veya teslim edilmesidir): "İkinci" etkinlik, "ilk" etkinlikten en az offsetDuration
sonra başlamalıdır.
Birkaç öncelik aynı (veya ilgili) etkinliklere atıfta bulunabilir. Örneğin: "B teslimatı A teslimatından sonra gerçekleşir" ve "C teslimatı B teslimatından sonra gerçekleşir".
Ayrıca, öncelik yalnızca her iki gönderim de yapıldığında geçerli olur ve aksi takdirde yoksayılır.
JSON gösterimi |
---|
{ "firstIsDelivery": boolean, "secondIsDelivery": boolean, "offsetDuration": string, "firstIndex": integer, "secondIndex": integer } |
Alanlar | |
---|---|
firstIsDelivery |
"İlk" etkinliğin bir yayın olup olmadığını belirtir. |
secondIsDelivery |
"İkinci" etkinliğin bir yayın olup olmadığını belirtir. |
offsetDuration |
"Birinci" ve "ikinci" etkinlik arasındaki ofset. Negatif olabilir. En fazla dokuz kesirli basamak içeren ve " |
firstIndex |
"İlk" etkinliğin gönderim dizini. Bu alan belirtilmelidir. |
secondIndex |
"İkinci" etkinliğin gönderim dizini. Bu alan belirtilmelidir. |