Este exemplo mostra como usar parâmetros de custo para conseguir uma rota econômica.
Para uma visão geral conceitual completa, consulte o documento Conceito principal do modelo de custo.
Exemplo de solicitação
O exemplo a seguir demonstra um cenário em que um veículo precisa entregar três remessas. O veículo tem custos associados de tempo e distância, e cada envio tem um penaltyCost que é incorrido se o envio for ignorado.
Este exemplo de solicitação contém os seguintes parâmetros relacionados a custos:
shipments[0]com umpenaltyCostde 100,0.shipments[1]com umpenaltyCostde 5,0.shipments[2]com umpenaltyCostde 50,0.vehicles[0]com umcostPerHourde 40,0 e umcostPerKilometerde 10,0.
Confira um exemplo de solicitação com custos
{ "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 } ] } }
Exemplo de resposta
A resposta mostra que o otimizador cria uma rota que realiza dois dos três envios. O terceiro envio é ignorado porque o penaltyCost é menor do que os custos calculados do veículo para coleta e entrega.
Confira uma resposta à solicitação de exemplo com custos
{ "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 } } }
Os campos a seguir mostram como os custos são calculados na resposta:
routeCostsdetalha os custos operacionais de uma rota específica, que neste caso são:model.vehicles.cost_per_kilometer: 33,53.model.vehicles.cost_per_hour: 18,91.
- O
routeTotalCost(52,44) é a soma dos custos listados emrouteCosts. - No nível superior da resposta, o objeto
costsresume todos os custos incorridos na solução. Isso inclui os custos operacionais de todas as rotas de veículos, além de penalidades, como amodel.shipments.penalty_cost(5,0) para o envio ignorado. - O
totalCostfinal (57,44) representa o total geral da solução, que é a soma dorouteTotalCostde todos os veículos e todos os custos de penalidade. Nesse caso, é 52,44 + 5,0.