or-tools:如果`num_nurses`不等于`num_shifts`

时间:2018-11-14 14:55:41

标签: or-tools

我正尝试使用Google或工具熟悉。我尝试了Employee调度python示例的简化版本。

from __future__ import print_function
import sys
from ortools.constraint_solver import pywrapcp


def main():
    # Creates the solver.
    solver = pywrapcp.Solver("employee_scheduling")

    num_nurses = 3
    num_shifts = 3
    num_days = 1

    # [START]
    # Create shift variables.
    shifts = {}

    for j in range(num_nurses):
        for i in range(num_days):
            shifts[(j, i)] = solver.IntVar(
                0, num_shifts - 1, "shifts(%i,%i)" % (j, i))
    shifts_flat = [shifts[(j, i)] for j in range(num_nurses)
                for i in range(num_days)]

    # Create nurse variables.
    nurses = {}

    for j in range(num_shifts):
        for i in range(num_days):
            nurses[(j, i)] = solver.IntVar(
                0, num_nurses - 1, "shift%d day%d" % (j, i))
    # Set relationships between shifts and nurses.
    for day in range(num_days):
        nurses_for_day = [nurses[(j, day)] for j in range(num_shifts)]

        for j in range(num_nurses):
            s = shifts[(j, day)]
            solver.Add(s.IndexOf(nurses_for_day) == j)

    # Create the decision builder.
    db = solver.Phase(shifts_flat, solver.CHOOSE_FIRST_UNBOUND,
                    solver.ASSIGN_MIN_VALUE)
    # Create the solution collector.
    solution = solver.Assignment()
    solution.Add(shifts_flat)
    collector = solver.AllSolutionCollector(solution)

    solver.Solve(db, [collector])
    print("Solutions found:", collector.SolutionCount())
    print("Time:", solver.WallTime(), "ms")
    print()


if __name__ == "__main__":
    main()

如您所见,我所保留的唯一限制是轮班与护士之间的关系。 在num_nurses = 3,num_shifts = 3和num_days = 1的情况下,求解程序可以找到6个解。但是,如果我将num_shifts更改为2,则求解器将返回0个解决方案。 这还不应该有3个解决方案(指派一名护士,让其他两名未指派)吗?

2 个答案:

答案 0 :(得分:0)

事实证明,这是目前对employee_scheduling编写方式的限制。目前正在对其进行重写,应该在几周内完成。

https://github.com/google/or-tools/issues/932

答案 1 :(得分:0)

我建议此版本的轮班调度实现一些不同的约束:

https://github.com/google/or-tools/blob/master/examples/python/shift_scheduling_sat.py

相关问题