Route Optimization API จะแสดงเส้นทางสำหรับยานพาหนะในคำขอที่เกี่ยวข้อง ระบบจะกำหนดการจัดส่งให้กับยานพาหนะ หรืออาจข้ามไปก็ได้ ทั้งนี้ขึ้นอยู่กับพร็อพเพอร์ตี้ของคำขอ
OptimizeToursResponseข้อความ (REST, gRPC) มีพร็อพเพอร์ตี้ระดับบนสุดหลัก 2 รายการดังนี้
routes[]คือเส้นทางของยานพาหนะแต่ละคันพร้อมการจัดส่งที่กำหนด แต่ละRouteจะมีเมตริกที่แสดงถึงคุณสมบัติของเส้นทางนั้นๆmetricsคือเมตริกที่รวบรวมไว้สําหรับการตอบสนองทั้งหมดในยานพาหนะและแผนเส้นทางทั้งหมด เมตริกระดับบนสุดมีพร็อพเพอร์ตี้เดียวกันกับเมตริกต่อเส้นทาง โดยมีค่าที่รวบรวมไว้ในเส้นทางทั้งหมด
ระบบอาจไม่ป้อนข้อมูลพร็อพเพอร์ตี้บางรายการเสมอไป ทั้งนี้ขึ้นอยู่กับผลการเพิ่มประสิทธิภาพ
skippedShipments[]แสดงการจัดส่งที่ไม่ได้ดำเนินการโดยยานพาหนะ คุณสามารถข้ามการจัดส่งได้หากดำเนินการภายในข้อจำกัดที่ระบุไม่ได้ หรือหากต้นทุนในการดำเนินการจัดส่งสูงกว่าค่าปรับ ตัวอย่างเช่น หากการรับหรือนำส่งสินค้ามีการระบุช่วงเวลาที่แคบมากtimeWindowยานพาหนะอาจไม่สามารถหรือไม่มีประสิทธิภาพในการ เข้าถึงในช่วงเวลาที่กำหนดvalidationErrors[]ระบุข้อผิดพลาดที่ทำให้คำขอไม่ถูกต้องหรือ แก้ไขไม่ได้เมื่อตั้งค่าsolvingModeของคำขอเป็นVALIDATE_ONLYในDEFAULT_SOLVEโหมดปกติ ข้อผิดพลาดในการตรวจสอบจะ ปรากฏในข้อความแสดงข้อผิดพลาดแทนเนื้อหาการตอบกลับ โปรดทราบว่าVALIDATE_ONLYโหมดการแก้ปัญหาจะรายงานข้อผิดพลาดหลายรายการพร้อมกันได้ ซึ่ง มีประโยชน์สำหรับการแก้ไขข้อบกพร่องของคำขออย่างรวดเร็ว
คุณสมบัติของเส้นทาง
แต่ละroutes[]รายการคือShipmentRouteข้อความ (REST, gRPC) แต่ละรายการ
ShipmentRouteแสดงการกำหนดเส้นทางสำหรับยานพาหนะหนึ่งๆ จากคำขอ ShipmentRouteพร็อพเพอร์ตี้Vehicleที่สำคัญซึ่งเกี่ยวข้องกับShipmentRouteพร็อพเพอร์ตี้Vehicleที่สอดคล้องกัน ได้แก่
vehicleIndexคือดัชนีที่อิงตาม 0 ของVehicleในข้อความคำขอที่เกี่ยวข้อง การตอบสนอง REST จะละเว้นคุณสมบัตินี้เมื่อค่าเป็นศูนย์vehicleStartTimeคือเวลาที่ยานพาหนะต้องเริ่มเส้นทางvehicleEndTimeคือเวลาที่คาดว่ายานพาหนะจะสิ้นสุดเส้นทาง
ในคำตอบ routes จะมีลักษณะดังนี้
{
"routes": [
{
"vehicleStartTime": "2024-02-13T00:00:00Z",
"vehicleEndTime": "2024-02-13T00:38:42Z",
"visits": [
...
],
"transitions": [
...
],
"metrics": {
...
},
...
}
],
...
}
ShipmentRoute แต่ละรายการจะมีรายการสั่งซื้อ visits ที่ยานพาหนะจะต้องดำเนินการให้เสร็จสมบูรณ์ แต่ละ Visit (REST, gRPC) แสดงถึง VisitRequest
(REST, gRPC) จากคำขอที่เกี่ยวข้อง คุณสมบัติที่สำคัญของ Visit ได้แก่:
shipmentIndexคือดัชนีฐานศูนย์ของการจัดส่งที่การเยี่ยมชมครั้งนี้เป็นของคำขอที่เกี่ยวข้องisPickupเป็นจริงเมื่อการเข้าชมเป็นการรับสินค้า และเป็นเท็จเมื่อการเข้าชมเป็นการนำส่ง การตอบกลับ REST จะละเว้นพร็อพเพอร์ตี้นี้เมื่อค่าเป็นเท็จvisitRequestIndexคือดัชนีฐานศูนย์ของVisitRequestจากShipment.pickupsหรือShipment.deliveriesในคำขอที่สอดคล้องกันที่Visitเป็นตัวแทน การตอบสนอง REST จะละเว้นคุณสมบัตินี้เมื่อค่าเป็นศูนย์startTimeคือเวลาที่คาดว่าจะเริ่มการเข้าชมloadDemandsแมปประเภทการโหลดเพื่อโหลดปริมาณที่ต้องการเพื่อทำให้Visitเสร็จสมบูรณ์ จำนวนโหลดจะเป็นค่าลบสำหรับการเยี่ยมชมการจัดส่ง ซึ่งแสดงถึงการโหลดที่ถูกเอาออกจากยานพาหนะ
ตัวอย่าง Visit มีลักษณะดังนี้:
{
"routes": [
{
...
"visits": [
{
"isPickup": true,
"startTime": "2024-02-13T00:00:00Z",
"detour": "0s"
},
...
],
},
...
],
...
}
ShipmentRoute แต่ละรายการจะมีรายการที่เรียงลำดับของ transitions ซึ่งแสดงถึง
การเดินทางระหว่าง visits สำหรับยานพาหนะที่กำหนด พร็อพเพอร์ตี้ที่สำคัญของTransitionข้อความ
(REST, gRPC) มีดังนี้
startTimeคือเวลาที่รถจะเริ่มทำการเปลี่ยนtravelDurationคือระยะเวลาที่ยานพาหนะต้องเดินทางเพื่อ เปลี่ยนเลนให้เสร็จสมบูรณ์travelDistanceMetersคือระยะทางเป็นเมตรที่ยานพาหนะต้อง เดินทางเพื่อทำการเปลี่ยนผ่านให้เสร็จสมบูรณ์trafficInfoUnavailableจะระบุว่ามีข้อมูลการเข้าชมสำหรับการเปลี่ยนเส้นทางหรือไม่waitDurationแสดงเวลาที่ไม่ได้ใช้งานซึ่งยานพาหนะใช้ในการรอ ก่อนที่จะเริ่มVisitครั้งถัดไปได้ ซึ่งอาจเกิดขึ้นเนื่องจากstart_timeของVisitต่อไปนี้totalDurationคือระยะเวลาทั้งหมดของการเปลี่ยนผ่าน ซึ่งรวมถึงเวลาเดินทาง เวลารอ เวลาพัก และเวลาที่ล่าช้าvehicleLoadsแมปประเภทการโหลดกับปริมาณการโหลดที่ยานพาหนะบรรทุกในระหว่างการเปลี่ยนนี้
ตัวอย่าง Transition มีลักษณะดังนี้
{
"routes": [
{
...
"transitions": [
...
{
"travelDuration": "1171s",
"travelDistanceMeters": 9004,
"waitDuration": "0s",
"totalDuration": "1171s",
"startTime": "2024-02-13T00:00:00Z"
},
...
],
...
}
],
...
}
สำหรับข้อมูลเพิ่มเติมเกี่ยวกับความสัมพันธ์ระหว่าง vists และ transitions โปรดดูที่การเพิ่มประสิทธิภาพคำสั่งซื้อแบบหยุดรับและจัดส่งและเอกสารอ้างอิง ShipmentRoute (REST, gRPC) สำหรับข้อมูลเพิ่มเติมเกี่ยวกับคุณสมบัติ routePolyline และ routeToken ของข้อความ Transition โปรดดูที่โพลีไลน์การเปลี่ยนผ่านและโทเค็นเส้นทาง
พร็อพเพอร์ตี้เมตริก
ข้อความ Metrics (REST, gRPC) สรุปโซลูชันทั้งหมด
คุณสมบัติที่สำคัญบางประการของ Metrics ได้แก่:
totalCostคือต้นทุนทั้งหมดที่เกิดขึ้นในการเดินทางตามเส้นทาง อ่านเพิ่มเติม เกี่ยวกับต้นทุนในพารามิเตอร์รูปแบบต้นทุนusedVehicleCountคือจำนวนยานพาหนะทั้งหมดที่ใช้ในโซลูชัน รถอาจมีเส้นทางว่างเปล่าเมื่อเครื่องมือเพิ่มประสิทธิภาพพิจารณาว่าการใช้รถ ไม่จำเป็นskippedMandatoryShipmentCountคือจำนวนการจัดส่งที่ข้ามซึ่ง "ต้องดำเนินการ" การจัดส่งแบบบังคับไม่ได้ระบุpenaltyCostที่จะเกิดขึ้นเมื่อข้ามการจัดส่ง คุณยังคงข้ามการจัดส่งที่จำเป็นได้หากประสิทธิภาพไม่เป็นไปตามข้อจำกัดที่ระบุ อ่านเพิ่มเติมเกี่ยวกับต้นทุนได้ในพารามิเตอร์รูปแบบต้นทุน
เมตริกเพิ่มเติมจะรายงานเป็นAggregatedMetricsข้อความ (REST,
gRPC) ประเภทข้อความ AggregatedMetrics ใช้สำหรับพร็อพเพอร์ตี้ Metrics.aggregatedRouteMetrics และสำหรับพร็อพเพอร์ตี้ ShipmentRoute.metrics
พร็อพเพอร์ตี้ Metrics.aggregatedRouteMetrics มีเมตริกที่รวบรวมจาก ShipmentRoute ทั้งหมดใน OptimizeToursResponse พร็อพเพอร์ตี้ ShipmentRoute.metrics แต่ละรายการมีเมตริกสำหรับ ShipmentRoute นั้นๆ
AggregatedMetricsพร็อพเพอร์ตี้ที่สำคัญAggregatedMetricsมีดังนี้
performedShipmentCountคือจำนวนการจัดส่งที่ยานพาหนะดำเนินการ ตลอดเส้นทางtravelDurationคือเวลารวมที่ยานพาหนะใช้ในการเดินทางขณะ ทำเส้นทางให้เสร็จสมบูรณ์waitDurationคือเวลารวมที่ยานพาหนะใช้ในการรอขณะที่ทำตามเส้นทางdelayDurationคือเวลาล่าช้ารวมของยานพาหนะ โดยปกติแล้วค่านี้จะเป็น 0 เว้นแต่จะใช้TransitionAttributesในคำขอbreakDurationคือเวลารวมที่ยานพาหนะใช้ในการหยุดพักขณะ ทำเส้นทางให้เสร็จสมบูรณ์visitDurationคือระยะเวลาทั้งหมดที่ยานพาหนะใช้ในการเข้าชมขณะ เดินทางตามเส้นทาง ซึ่งก็คือผลรวมของค่าVisitRequest.durationทั้งหมดสำหรับVisitRequestที่สอดคล้องกับVisitที่ กำหนดให้กับยานพาหนะที่เกี่ยวข้องtotalDurationคือระยะเวลาทั้งหมดที่ต้องใช้ในการเดินทางตามเส้นทางของยานพาหนะtravelDistanceMetersคือระยะทางรวมที่ยานพาหนะเดินทางขณะ ทำตามเส้นทางmaxLoadsจะแมปประเภทการโหลดกับปริมาณการโหลดสูงสุดที่ยานพาหนะ บรรทุกในเส้นทาง
ตัวอย่างข้อความ Metrics มีลักษณะดังนี้
{
"routes": [
...
],
"metrics": {
"aggregatedRouteMetrics": {
"performedShipmentCount": 1,
"travelDuration": "2322s",
"waitDuration": "0s",
"delayDuration": "0s",
"breakDuration": "0s",
"visitDuration": "0s",
"totalDuration": "2322s",
"travelDistanceMeters": 18603
},
"usedVehicleCount": 1,
"earliestVehicleStartTime": "2024-02-13T00:00:00Z",
"latestVehicleEndTime": "2024-02-13T00:38:42Z",
"totalCost": 18.603,
"costs": {
"model.vehicles.cost_per_kilometer": 18.603
}
}
}
ตัวอย่างที่สมบูรณ์
การตอบกลับตัวอย่างที่สมบูรณ์สำหรับคำขอจากสร้างคำขอมีลักษณะดังนี้
{
"routes": [
{
"vehicleStartTime": "2024-02-13T00:00:00Z",
"vehicleEndTime": "2024-02-13T00:38:42Z",
"visits": [
{
"isPickup": true,
"startTime": "2024-02-13T00:00:00Z",
"detour": "0s"
},
{
"startTime": "2024-02-13T00:19:31Z",
"detour": "0s"
}
],
"transitions": [
{
"travelDuration": "0s",
"waitDuration": "0s",
"totalDuration": "0s",
"startTime": "2024-02-13T00:00:00Z"
},
{
"travelDuration": "1171s",
"travelDistanceMeters": 9004,
"waitDuration": "0s",
"totalDuration": "1171s",
"startTime": "2024-02-13T00:00:00Z"
},
{
"travelDuration": "1151s",
"travelDistanceMeters": 9599,
"waitDuration": "0s",
"totalDuration": "1151s",
"startTime": "2024-02-13T00:19:31Z"
}
],
"metrics": {
"performedShipmentCount": 1,
"travelDuration": "2322s",
"waitDuration": "0s",
"delayDuration": "0s",
"breakDuration": "0s",
"visitDuration": "0s",
"totalDuration": "2322s",
"travelDistanceMeters": 18603
},
"routeCosts": {
"model.vehicles.cost_per_kilometer": 18.603
},
"routeTotalCost": 18.603
}
],
"metrics": {
"aggregatedRouteMetrics": {
"performedShipmentCount": 1,
"travelDuration": "2322s",
"waitDuration": "0s",
"delayDuration": "0s",
"breakDuration": "0s",
"visitDuration": "0s",
"totalDuration": "2322s",
"travelDistanceMeters": 18603
},
"usedVehicleCount": 1,
"earliestVehicleStartTime": "2024-02-13T00:00:00Z",
"latestVehicleEndTime": "2024-02-13T00:38:42Z",
"totalCost": 18.603,
"costs": {
"model.vehicles.cost_per_kilometer": 18.603
}
}
}