پارامترهای مدل هزینه

پیام 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 هزینه ای را نشان می دهد که با نادیده گرفتن حمل و نقل انجام می شود.
  • Shipment.VisitRequest.cost نشان‌دهنده هزینه یک تحویل یا تحویل خاص است که عمدتاً برای فعال کردن مبادلات هزینه بین گزینه‌های تحویل یا تحویل چندگانه برای یک محموله استفاده می‌شود.

پارامترهای هزینه Shipment از واحدهای بدون بعد مشابه پارامترهای هزینه Vehicle استفاده می کنند. هزینه انجام شده برای تکمیل یک Shipment بیشتر از هزینه جریمه آن است، Shipment در مسیر هیچ یک Vehicle لحاظ نمی شود و در عوض در لیست skipped_shipments در پیام پاسخ ظاهر می شود.

ویژگی های هزینه ShipmentModel

پیام ShipmentModel ( REST ، gRPC ) شامل یک ویژگی هزینه واحد، 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 واحد است که با کل کلید model.shipments.penalty_cost در پاسخ مثال مطابقت دارد. penaltyCost پایین Vehicle در مقایسه با costPerHour هر ساعت 40.0 و costPerKilometer 10.0، نادیده گرفتن حمل و نقل را مقرون به صرفه تر از تکمیل آن می کند.

موضوع پیشرفته: هزینه ها و محدودیت های نرم

چندین ویژگی پیام 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 به تفصیل در Load Demands و Limits مطرح می شوند. محدودیت‌های TimeWindow به تفصیل در محدودیت‌های پنجره زمان تحویل و تحویل پرداخته شده است.