Implement shift perturbation
This commit is contained in:
parent
aef55abe54
commit
c7117a5b92
@ -7,6 +7,7 @@ class TableSimulatorJob < ApplicationJob
|
|||||||
engine = VNS::Engine.new
|
engine = VNS::Engine.new
|
||||||
|
|
||||||
engine.add_perturbation(Tables::Swap)
|
engine.add_perturbation(Tables::Swap)
|
||||||
|
engine.add_perturbation(Tables::Shift)
|
||||||
|
|
||||||
initial_solution = Tables::Distribution.new(min_per_table: 8, max_per_table: 10)
|
initial_solution = Tables::Distribution.new(min_per_table: 8, max_per_table: 10)
|
||||||
initial_solution.random_distribution(Guest.potential.shuffle)
|
initial_solution.random_distribution(Guest.potential.shuffle)
|
||||||
|
30
app/services/tables/shift.rb
Normal file
30
app/services/tables/shift.rb
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# Copyright (C) 2024 Manuel Bustillo
|
||||||
|
|
||||||
|
module Tables
|
||||||
|
class Shift
|
||||||
|
private attr_reader :initial_solution
|
||||||
|
def initialize(initial_solution)
|
||||||
|
@initial_solution = initial_solution
|
||||||
|
end
|
||||||
|
|
||||||
|
def each
|
||||||
|
@initial_solution.tables.permutation(2) do |table_a, table_b|
|
||||||
|
table_a.each do |person|
|
||||||
|
original_discomfort_a = table_a.reset
|
||||||
|
original_discomfort_b = table_b.reset
|
||||||
|
|
||||||
|
table_a.delete(person)
|
||||||
|
table_b << person
|
||||||
|
|
||||||
|
yield(@initial_solution)
|
||||||
|
ensure
|
||||||
|
table_b.delete(person)
|
||||||
|
table_a << person
|
||||||
|
|
||||||
|
table_a.discomfort = original_discomfort_a
|
||||||
|
table_b.discomfort = original_discomfort_b
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
6
spec/services/tables/shift_spec.rb
Normal file
6
spec/services/tables/shift_spec.rb
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
module Tables
|
||||||
|
RSpec.describe Shift do
|
||||||
|
end
|
||||||
|
end
|
Loading…
x
Reference in New Issue
Block a user