OptimizeToursRequest
ข้อความ (REST, gRPC) มีพร็อพเพอร์ตี้หลายรายการที่เกี่ยวข้องกับค่าใช้จ่าย
พารามิเตอร์ต้นทุนเหล่านี้รวมกันแสดงถึงรูปแบบต้นทุนของคำขอ รูปแบบต้นทุนจะบันทึกวัตถุประสงค์ในการเพิ่มประสิทธิภาพระดับสูงของคำขอหลายรายการ เช่น
- ให้ความสำคัญกับเส้นทางที่เร็วกว่า
Vehicle
มากกว่าเส้นทางที่สั้นกว่า หรือในทางกลับกัน - การพิจารณาว่าต้นทุนในการส่งมอบ
Shipment
คุ้มค่ากับมูลค่าของShipment
ที่ทำเสร็จหรือไม่ - รับและนำส่งภายในกรอบเวลาเฉพาะเมื่อการดำเนินการดังกล่าว คุ้มค่า
ดูตัวอย่างคำขอพร้อมค่าใช้จ่าย
{ "model": { "globalStartTime": "2023-01-13T16:00:00-08:00", "globalEndTime": "2023-01-14T16:00:00-08:00", "shipments": [ { "deliveries": [ { "arrivalLocation": { "latitude": 37.789456, "longitude": -122.390192 }, "duration": "250s" } ], "pickups": [ { "arrivalLocation": { "latitude": 37.794465, "longitude": -122.394839 }, "duration": "150s" } ], "penaltyCost": 100.0 }, { "deliveries": [ { "arrivalLocation": { "latitude": 37.789116, "longitude": -122.395080 }, "duration": "250s" } ], "pickups": [ { "arrivalLocation": { "latitude": 37.794465, "longitude": -122.394839 }, "duration": "150s" } ], "penaltyCost": 5.0 }, { "deliveries": [ { "arrivalLocation": { "latitude": 37.795242, "longitude": -122.399347 }, "duration": "250s" } ], "pickups": [ { "arrivalLocation": { "latitude": 37.794465, "longitude": -122.394839 }, "duration": "150s" } ], "penaltyCost": 50.0 } ], "vehicles": [ { "endLocation": { "latitude": 37.794465, "longitude": -122.394839 }, "startLocation": { "latitude": 37.794465, "longitude": -122.394839 }, "costPerHour": 40.0, "costPerKilometer": 10.0 } ] } }
พร็อพเพอร์ตี้ค่าใช้จ่าย Vehicle
ข้อความ Vehicle
(REST, gRPC) มีพร็อพเพอร์ตี้ค่าใช้จ่ายหลายรายการ ดังนี้
Vehicle.cost_per_hour
: แสดงต้นทุนการใช้งานยานพาหนะต่อชั่วโมง รวมถึงเวลาขนส่ง เวลาพัก เวลาที่ใช้ในการเข้าชม และเวลาพักVehicle.cost_per_kilometer
: แสดงต้นทุนต่อกิโลเมตรที่ยานพาหนะวิ่งVehicle.cost_per_traveled_hour
: แสดงถึงต้นทุนการใช้งานยานพาหนะ ขณะเดินทางเท่านั้น โดยไม่รวมเวลาที่รอ เวลาที่เข้าชม และเวลาพัก
พารามิเตอร์ต้นทุนเหล่านี้ช่วยให้เครื่องมือเพิ่มประสิทธิภาพสามารถทำการแลกเปลี่ยนระหว่างเวลาและระยะทางที่เดินทาง
ต้นทุนที่เกิดจากเส้นทางที่เพิ่มประสิทธิภาพจะปรากฏในข้อความตอบกลับเป็น metrics.costs
เมื่อ costPerHour
เพิ่มขึ้น ตัวเพิ่มประสิทธิภาพจะพยายามค้นหาเส้นทางที่เร็วกว่า
ซึ่งอาจไม่ใช่เส้นทางที่สั้นที่สุด ในตัวอย่างนี้ เส้นทางที่เร็วที่สุดเป็นเส้นทางที่สั้นที่สุดด้วย ดังนั้นการเปลี่ยนแปลงพารามิเตอร์ต้นทุนจึงมีผลเพียงเล็กน้อย
พร็อพเพอร์ตี้ค่าใช้จ่าย Shipment
ข้อความ Shipment
(REST, gRPC) ยังมีพารามิเตอร์ค่าใช้จ่ายหลายรายการ
ดังนี้
Shipment.penalty_cost
แสดงต้นทุนที่เกิดขึ้นจากการข้ามการจัดส่ง การไม่ตั้งค่าพารามิเตอร์penalty_cost
ของการจัดส่งจะทำให้การจัดส่งเป็นแบบบังคับ ซึ่งหมายความว่าระบบจะข้ามการจัดส่งก็ต่อเมื่อดำเนินการให้เสร็จสมบูรณ์ไม่ได้เนื่องจากข้อจำกัดที่ระบุShipment.VisitRequest.cost
แสดงถึงต้นทุนของการรับสินค้าหรือการนำส่งที่เฉพาะเจาะจง ซึ่งใช้เป็นหลักในการเปรียบเทียบต้นทุนระหว่างตัวเลือกการรับสินค้าหรือการนำส่งหลายรายการสำหรับการจัดส่งครั้งเดียว
พารามิเตอร์ต้นทุน Shipment
ใช้หน่วยที่ไม่มีมิติเดียวกันกับพารามิเตอร์ต้นทุน Vehicle
หากต้นทุนที่เกิดขึ้นในการทำShipment
ให้เสร็จสมบูรณ์สูงกว่าต้นทุนค่าปรับ
Shipment
จะไม่รวมอยู่ในเส้นทางของVehicle
ใดๆ แต่จะปรากฏในรายการskipped_shipments
ในข้อความตอบกลับแทน
พร็อพเพอร์ตี้ค่าใช้จ่าย ShipmentModel
ข้อความ ShipmentModel
(REST, gRPC) มีพร็อพเพอร์ตี้ cost
รายการเดียว globalDurationCostPerHour
ค่าใช้จ่ายนี้จะเกิดขึ้นตามเวลาทั้งหมดที่ยานพาหนะทุกคันต้องใช้ในการทำShipmentRoute
ให้เสร็จสมบูรณ์ การเพิ่ม
globalDurationCostPerHour
จะช่วยให้การนำส่งทั้งหมดเสร็จสมบูรณ์ได้เร็วขึ้น
พร็อพเพอร์ตี้ต้นทุนการตอบกลับการเพิ่มประสิทธิภาพเส้นทาง
ข้อความ OptimizeToursResponse
(REST, gRPC) มีพร็อพเพอร์ตี้ค่าใช้จ่าย
ที่แสดงถึงค่าใช้จ่ายที่เกิดขึ้นในกระบวนการทำ ShipmentRoute
ให้เสร็จสมบูรณ์
พร็อพเพอร์ตี้ metrics.costs
และ metrics.totalCost
แสดงจำนวน
หน่วยต้นทุนที่เกิดขึ้นในเส้นทางทั้งหมดในการตอบกลับ รายการ routes
แต่ละรายการมีพร็อพเพอร์ตี้ routeCosts
และ routeTotalCosts
ที่แสดงค่าใช้จ่ายสำหรับเส้นทางนั้นๆ
ดูการตอบกลับคำขอตัวอย่างพร้อมค่าใช้จ่าย
{ "routes": [ { "vehicleStartTime": "2023-01-14T00:00:00Z", "vehicleEndTime": "2023-01-14T00:28:22Z", "visits": [ { "isPickup": true, "startTime": "2023-01-14T00:00:00Z", "detour": "0s" }, { "shipmentIndex": 2, "isPickup": true, "startTime": "2023-01-14T00:02:30Z", "detour": "150s" }, { "startTime": "2023-01-14T00:08:55Z", "detour": "150s" }, { "shipmentIndex": 2, "startTime": "2023-01-14T00:21:21Z", "detour": "572s" } ], "transitions": [ { "travelDuration": "0s", "waitDuration": "0s", "totalDuration": "0s", "startTime": "2023-01-14T00:00:00Z" }, { "travelDuration": "0s", "waitDuration": "0s", "totalDuration": "0s", "startTime": "2023-01-14T00:02:30Z" }, { "travelDuration": "235s", "travelDistanceMeters": 795, "waitDuration": "0s", "totalDuration": "235s", "startTime": "2023-01-14T00:05:00Z" }, { "travelDuration": "496s", "travelDistanceMeters": 1893, "waitDuration": "0s", "totalDuration": "496s", "startTime": "2023-01-14T00:13:05Z" }, { "travelDuration": "171s", "travelDistanceMeters": 665, "waitDuration": "0s", "totalDuration": "171s", "startTime": "2023-01-14T00:25:31Z" } ], "metrics": { "performedShipmentCount": 2, "travelDuration": "902s", "waitDuration": "0s", "delayDuration": "0s", "breakDuration": "0s", "visitDuration": "800s", "totalDuration": "1702s", "travelDistanceMeters": 3353 }, "routeCosts": { "model.vehicles.cost_per_kilometer": 33.53, "model.vehicles.cost_per_hour": 18.911111111111111 }, "routeTotalCost": 52.441111111111113 } ], "skippedShipments": [ { "index": 1 } ], "metrics": { "aggregatedRouteMetrics": { "performedShipmentCount": 2, "travelDuration": "902s", "waitDuration": "0s", "delayDuration": "0s", "breakDuration": "0s", "visitDuration": "800s", "totalDuration": "1702s", "travelDistanceMeters": 3353 }, "usedVehicleCount": 1, "earliestVehicleStartTime": "2023-01-14T00:00:00Z", "latestVehicleEndTime": "2023-01-14T00:28:22Z", "totalCost": 57.441111111111113, "costs": { "model.vehicles.cost_per_kilometer": 33.53, "model.vehicles.cost_per_hour": 18.911111111111111, "model.shipments.penalty_cost": 5 } } }
ในการตอบกลับตัวอย่าง metrics.costs
ระดับบนสุดคือ
{
"metrics": {
...
"costs": {
"model.vehicles.cost_per_hour": 18.911111111111111,
"model.vehicles.cost_per_kilometer": 33.53,
"model.shipments.penalty_cost": 5
}
}
}
ค่า model.shipments.penalty_cost
แสดงถึงต้นทุนที่เกิดขึ้นเนื่องจาก
การจัดส่งที่ถูกข้าม พร็อพเพอร์ตี้ skippedShipments
จะแสดงการจัดส่งที่ข้ามไป
ในตัวอย่างนี้ ระบบจะข้ามเฉพาะ model.shipments[1]
ในคำขอตัวอย่าง
model.shipments[1]
มีค่าใช้จ่ายในการลงโทษ 5 หน่วย ซึ่งตรงกับคีย์ total
model.shipments.penalty_cost
ในการตอบกลับตัวอย่าง penaltyCost
ของสินค้าที่จัดส่งต่ำกว่า Vehicle
40.0 costPerHour
และ 10.0
costPerKilometer
ทำให้การข้ามการจัดส่งคุ้มค่ากว่าการ
ดำเนินการให้เสร็จสมบูรณ์
หัวข้อขั้นสูง: ค่าใช้จ่ายและข้อจำกัดแบบยืดหยุ่น
พร็อพเพอร์ตี้ของOptimizeToursRequest
ข้อความ (REST, gRPC) หลายรายการ
แสดงถึงข้อจำกัดแบบยืดหยุ่น ซึ่งเป็นข้อจำกัดที่ทำให้เกิดค่าใช้จ่ายเมื่อ
ไม่สามารถปฏิบัติตามได้
เช่น ข้อจำกัดของยานพาหนะ LoadLimit
(REST, gRPC) มีพร็อพเพอร์ตี้ softMaxLoad
และ costPerUnitAboveSoftMax
การดำเนินการเหล่านี้จะทำให้เกิดค่าใช้จ่ายตามสัดส่วนของหน่วยโหลดที่เกิน softMaxLoad
ซึ่งจะอนุญาตให้เกินขีดจำกัดได้ก็ต่อเมื่อการดำเนินการดังกล่าวสมเหตุสมผลในแง่ของค่าใช้จ่าย
ในทํานองเดียวกัน TimeWindow
ข้อจํากัด (REST, gRPC) มีพร็อพเพอร์ตี้ soft_start_time
และ soft_end_time
พร้อมด้วยพร็อพเพอร์ตี้ cost_per_hour_before_soft_start_time
และ cost_per_hour_after_soft_end_time
ที่เกี่ยวข้อง
ซึ่งเกิดขึ้นตามเวลาที่เหตุการณ์ที่มีข้อจํากัดเกิดขึ้นเร็วหรือช้าเมื่อเทียบกับ TimeWindow
เช่นเดียวกับพารามิเตอร์โมเดลต้นทุนทั้งหมด ต้นทุนข้อจำกัดแบบยืดหยุ่นจะแสดงในหน่วยที่ไม่มีมิติเดียวกับพารามิเตอร์ต้นทุนอื่นๆ
LoadLimit
มีการกล่าวถึงข้อจำกัดโดยละเอียดใน
ความต้องการและขีดจำกัดของโหลด TimeWindow
ข้อจำกัดจะอธิบายโดยละเอียด
ในข้อจำกัดของกรอบเวลาการรับและการนำส่ง