Skip to content

Commit

Permalink
Auto generated IDs are integer
Browse files Browse the repository at this point in the history
  • Loading branch information
senhalil committed Aug 2, 2021
1 parent 0b5a1b6 commit ead024d
Showing 1 changed file with 12 additions and 12 deletions.
24 changes: 12 additions & 12 deletions wrappers/ortools.rb
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ def solve(vrp, job, thread_proc = nil, &block)
vehicle_indices: (service.sticky_vehicles.size > 0 && service.sticky_vehicles.collect{ |sticky_vehicle| vrp.vehicles.index(sticky_vehicle) }.compact.size > 0) ?
service.sticky_vehicles.collect{ |sticky_vehicle| vrp.vehicles.index(sticky_vehicle) }.compact : vehicles_indices,
setup_duration: service.activity.setup_duration,
id: service.id,
id: service.id.to_s,
late_multiplier: service.activity.late_multiplier || 0,
setup_quantities: vrp.units.collect{ |unit|
q = service.quantities.find{ |quantity| quantity.unit == unit }
Expand Down Expand Up @@ -272,7 +272,7 @@ def solve(vrp, job, thread_proc = nil, &block)
}
vehicles = vrp.vehicles.collect{ |vehicle|
OrtoolsVrp::Vehicle.new(
id: vehicle.id,
id: vehicle.id.to_s,
cost_fixed: vehicle.cost_fixed,
cost_distance_multiplier: vehicle.cost_distance_multiplier,
cost_time_multiplier: vehicle.cost_time_multiplier,
Expand Down Expand Up @@ -301,7 +301,7 @@ def solve(vrp, job, thread_proc = nil, &block)
OrtoolsVrp::TimeWindow.new(start: tw.start, end: tw.end || 2**56)
},
duration: rest.duration,
id: rest.id,
id: rest.id.to_s,
late_multiplier: rest.late_multiplier,
exclusion_cost: rest.exclusion_cost || -1
)
Expand Down Expand Up @@ -333,8 +333,8 @@ def solve(vrp, job, thread_proc = nil, &block)

OrtoolsVrp::Relation.new(
type: relation.type,
linked_ids: current_linked_ids,
linked_vehicle_ids: current_linked_vehicles,
linked_ids: current_linked_ids.map(&:to_s),
linked_vehicle_ids: current_linked_vehicles.map(&:to_s),
lapse: relation.lapse
)
}.compact
Expand All @@ -346,8 +346,8 @@ def solve(vrp, job, thread_proc = nil, &block)
next if service_ids.empty?

OrtoolsVrp::Route.new(
vehicle_id: route.vehicle.id,
service_ids: service_ids
vehicle_id: route.vehicle.id.to_s,
service_ids: service_ids.map(&:to_s)
)
}

Expand Down Expand Up @@ -701,15 +701,15 @@ def run_ortools(problem, vrp, services, points, matrix_indices, thread_proc = ni
end

def update_services_positions(services, services_positions, id, position, service_index)
services_positions[:always_first] << id if position == :always_first
services_positions[:never_first] << id if [:never_first, :always_middle].include?(position)
services_positions[:never_last] << id if [:never_last, :always_middle].include?(position)
services_positions[:always_last] << id if position == :always_last
services_positions[:always_first] << id.to_s if position == :always_first
services_positions[:never_first] << id.to_s if [:never_first, :always_middle].include?(position)
services_positions[:never_last] << id.to_s if [:never_last, :always_middle].include?(position)
services_positions[:always_last] << id.to_s if position == :always_last

return services if position != :never_middle

services + services.select{ |s| s.problem_index == service_index }.collect{ |s|
services_positions[:always_first] << id
services_positions[:always_first] << id.to_s
services_positions[:always_last] << "#{id}_alternative"
copy_s = s.dup
copy_s.id += '_alternative'
Expand Down

0 comments on commit ead024d

Please sign in to comment.