ตีความคำตอบ

Route Optimization API จะแสดงเส้นทางสำหรับยานพาหนะในคำขอที่เกี่ยวข้อง มีการกำหนดการจัดส่งให้กับยานพาหนะ หรือระบบอาจข้ามการจัดส่งขึ้นอยู่กับคุณสมบัติของคำขอ

ข้อความ OptimizeToursResponse (REST, gRPC) มีพร็อพเพอร์ตี้ระดับบนสุดหลัก 2 รายการ ได้แก่

  • routes[] คือเส้นทางสำหรับยานพาหนะแต่ละคันที่มีการจัดส่งที่กำหนด แต่ละ Route จะมีเมตริกที่แสดงพร็อพเพอร์ตี้ของแต่ละเส้นทาง
  • metrics เป็นเมตริกรวมสำหรับคำตอบทั้งหมดในทุกยานพาหนะและแผนเส้นทาง เมตริกระดับบนสุดมีพร็อพเพอร์ตี้เดียวกันกับเมตริกต่อเส้นทาง โดยจะรวมค่าไว้ในเส้นทางทั้งหมด

ระบบอาจไม่ได้ป้อนข้อมูลพร็อพเพอร์ตี้บางรายการเสมอไป ทั้งนี้ขึ้นอยู่กับผลการเพิ่มประสิทธิภาพ ดังนี้

  1. skippedShipments[] แสดงการจัดส่งที่ไม่ได้ดำเนินการโดยยานพาหนะใดๆ ระบบอาจข้ามการจัดส่งได้หากดำเนินการภายในข้อจำกัดที่ระบุไม่ได้ หรือหากค่าใช้จ่ายในการจัดส่งเกินค่าปรับ เช่น หากการมารับหรือนำส่งของที่จัดส่งมี timeWindow ที่แคบมาก ยานพาหนะดังกล่าวอาจไม่สามารถเดินทางในกรอบเวลาที่กำหนดได้หรือมีความคุ้มค่า
  2. validationErrors[] ระบุข้อผิดพลาดที่ทำให้คำขอไม่ถูกต้องหรือแก้ไขไม่ได้เมื่อตั้งค่า solvingMode ของคำขอเป็น VALIDATE_ONLY ในโหมด DEFAULT_SOLVE ปกติ ข้อผิดพลาดในการตรวจสอบจะปรากฏในข้อความแสดงข้อผิดพลาดแทนเนื้อหาการตอบกลับ โปรดทราบว่าโหมดแก้ไข VALIDATE_ONLY สามารถรายงานข้อผิดพลาดหลายรายการพร้อมกัน ซึ่งมีประโยชน์ต่อคำขอแก้ไขข้อบกพร่องอย่างรวดเร็ว

พร็อพเพอร์ตี้ของเส้นทาง

routes[] แต่ละรายการจะเป็นข้อความ ShipmentRoute (REST, gRPC) ShipmentRoute แต่ละรายการแสดงถึงการกําหนดเส้นทางสําหรับรถยนต์คันนั้นๆ จากคำขอ พร็อพเพอร์ตี้ ShipmentRoute ที่สำคัญที่เกี่ยวข้องกับ Vehicle ที่เกี่ยวข้อง ได้แก่

  • vehicleIndex คือดัชนีฐาน 0 ของ Vehicle ในข้อความคำขอที่เกี่ยวข้อง การตอบกลับ REST จะไม่แสดงพร็อพเพอร์ตี้นี้เมื่อค่าเป็น 0
  • 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 คือดัชนีฐาน 0 ของการจัดส่งที่การเข้าชมนี้อยู่ในคำขอที่เกี่ยวข้อง
  • isPickup เป็นจริงเมื่อการเข้าชมเป็นแบบมารับสินค้า และเป็นเท็จเมื่อการเข้าชมเป็นการแสดงโฆษณา การตอบกลับ REST จะไม่แสดงพร็อพเพอร์ตี้นี้เมื่อค่าเป็น "เท็จ"
  • visitRequestIndex คือดัชนีฐาน 0 ของ VisitRequest จาก Shipment.pickups หรือ Shipment.deliveries ในคำขอที่เกี่ยวข้องที่ Visit แสดง การตอบกลับ REST จะไม่แสดงพร็อพเพอร์ตี้นี้เมื่อค่าเป็น 0
  • 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)

พร็อพเพอร์ตี้เมตริก

ข้อความ Metrics (REST, gRPC) จะสรุปโซลูชันทั้งหมด พร็อพเพอร์ตี้ Metrics ที่สำคัญบางส่วนมีดังนี้

  • totalCost คือค่าใช้จ่ายทั้งหมดที่เกิดขึ้นในระหว่างเส้นทางทั้งหมด อ่านเพิ่มเติมเกี่ยวกับค่าใช้จ่ายในพารามิเตอร์โมเดลค่าใช้จ่าย
  • usedVehicleCount คือจำนวนยานพาหนะทั้งหมดที่ใช้ในโซลูชัน ยานพาหนะอาจมีเส้นทางว่างเปล่าเมื่อเครื่องมือเพิ่มประสิทธิภาพพิจารณาว่าไม่จำเป็น
  • skippedMandatoryShipmentCount คือจำนวนการจัดส่งที่ข้ามซึ่ง "บังคับ" การจัดส่งที่จำเป็นไม่ได้ระบุ penaltyCost ที่จะเกิดขึ้นหากข้ามการจัดส่ง การจัดส่งที่จำเป็นจะยังคงข้ามได้หากไม่สามารถดำเนินการได้ภายใต้ข้อจำกัดที่ระบุ อ่านเพิ่มเติมเกี่ยวกับค่าใช้จ่ายในพารามิเตอร์โมเดลค่าใช้จ่าย

เมตริกเพิ่มเติมจะรายงานเป็นข้อความ AggregatedMetrics (REST, gRPC) ประเภทข้อความ AggregatedMetrics ใช้สำหรับพร็อพเพอร์ตี้ Metrics.aggregatedRouteMetrics และสำหรับพร็อพเพอร์ตี้ ShipmentRoute.metrics Metrics.aggregatedRouteMetrics มีเมตริกที่รวบรวมจาก ShipmentRoute ทั้งหมดใน OptimizeToursResponse พร็อพเพอร์ตี้ ShipmentRoute.metrics แต่ละรายการมีเมตริกสำหรับ ShipmentRoute ที่เฉพาะเจาะจงนั้นๆ

พร็อพเพอร์ตี้ 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
    }
  }
}