given n jobs, their durations (between 3 and 9 indivisible time units) and 5 workers.
the goal is to create time schedule where all jobs would be assigned to workers while minimizing the timespan (time between start of 1st job and finish of last) using following rules:
- each worker can only work on 1 job per time
- each job can be assigned to 1 or 2 workers (out of any 5 workers)
- order of job execution doesn't matter
- if a job is assigned to 2 workers, they must start and finish together at the same time
- if a job is assigned to 2 workers, the job duration will be split by 2, if duration is odd number then both workers will work until the end of last time unit (e.g. if job duration is 7, they wil both work 4 time units)
- workers have a window of 18 time units per day, during which they can be assigned jobs, makespan of daily schedule of worker shouldn't exceed 18 time units.
- workers can have idle time between jobs.
- jobs can't be split to smaller jobs, only between 2 workers
crossover and mutation in GA inspired by this paper: https://www.researchgate.net/publication/281545095_SOLVING_JOB_SHOP_SCHEDULING_PROBLEM_WITH_GENETIC_ALGORITHM
example run for randomly generated jobs:
makespan reduction with each iteration:
best solution for 5 workers accross 5 days: