Solver

Screen description

In the Solver screen, you can load input data to the solver and run the solver in different configurations and modes. The operations available to you and the amount and kind of information displayed will depend on the status of the solver (the first item of the Solver section).

Solver not started

Solver

    • Status

        • Current status of the solver

    • Solver configuration

    • Solver mode

        • Options: Initial - creates a new timetable; MPP - continues working on the loaded timetable, trying to find a better timetable with as few differences from the loaded one as possible

    • When finished

        • Choose what to do when the time-out limit on the solver is reached

    • Allow breaking of hard constraints

        • Allow breaking of required/prohibited times/rooms. This is useful to be able to assign a prohibited time or room to a class using the Suggestions page while making interactive changes.

  • Student course demands

      • Student course demands that are used during the timetabling to avoid student conflicts

        • Last Like Student Course Demands

          • Real student course enrollments from the last-like semester

          • Source of demands: XML import

        • Weighted Last Like Student Course Demands

          • Real enrollments weighted so that the courses are filled with students

            • Example: When there were 15 students in a course last year and this year the course has a limit of 20, the last-like students in that course are multiplied by 20/15

          • Source of demands: XML import and class limits

        • Projected Student Course Demands

          • Projected demands calculated from the last-like student course demands using the projection rules from the Curriculum Projection Rules screen

          • Source of demands: XML import and Projection Rules

            • Unlike with Last Like Student Course Demands and Weighted Last Like Student Course Demands, in this case it is important to import students and their properties (academic areas, majors, and classifications), this XML import prior to importing last like student course demands.

        • Curricula Course Demands

        • Curricula Last Like Course Demands

          • A combination of curricula and (projected) last-like student course demands - the curricula help with course demands for new courses (and mandatory courses etc.) while the last-like information provides data about courses across curricula that the students took together

            • Use case: curricula only contain information about mandatory and elective courses, demands for optional courses are taken from last-like enrollment data. Last like data are also used to better estimate joint demands between courses.

          • Source of demands: XML import and Curricula

        • Student Course Requests

        • Enrolled Student Course Demands

          • Real enrollments of students for this semester that is being timetabled (used mainly for testing)

          • Source of demands: XML import

    • Student final sectioning

        • Solver will perform student sectioning as a final stage of solving the problem (i.e., when a complete solution is found for Check configuration or upon time-out for the other configurations) to have more accurate information about student conflicts

    • Owner

        • The solver group for which you want to create a timetable

    • Host (admin)

        • Select server you want to run the solver on (setting "auto" means that the least occupied solver will be used, this is the default behavior for non-administrator users)

Operations

    • Load

        • Load all input data necessary to create a timetable (instructional offerings, rooms, instructors, distribution preferences, last like semester student enrollments, ...) to the solver. If one or more timetables have been selected on the Timetables page, their assignments will be loaded into the solver as well.

    • Start

        • Load all necessary data and start creating a timetable

    • Refresh

        • Refresh this screen

Loading input data

During the loading phase, input data and student information is loaded and the classes which have only one required room and one required time will get them assigned.

Solver

    • Input data loaded

        • Time stamp from the time when the latest load of input data started

For the rest, see above

Current Timetable

An initial timetable is created as soon as you start loading data. Only classes with one required time and one required room get there assignments at this point.

See Solution Properties for the description of the items in this part of the screen.

Operations

    • Refresh

        • Refresh this screen

            • When loading is done, new buttons will appear

Awaiting commands

Operations

    • Start

        • Start the solver which will create/improve a timetable

    • Student Sectioning

        • Run student sectioning (this will try to change assignments of students between alternative classes of a course in order to minimize student conflicts)

    • Reload Input Data

        • Reload input data while keeping the current timetable

            • The assignments that are no longer valid due to the change in the input data will be unassigned (see the Not-Assigned Classes screen for their list)

    • Unload

        • Unload all data and the timetable from the solver

    • Export Solution

        • Export the solution in the CSV (comma separated values) format

    • Refresh

        • Refresh this screen

Solving problem

Solver

See above

Operations

    • Stop

        • Stop the solver

    • Refresh

        • Refresh this screen

Solver stopped

Best Timetable Found So Far

During the automated timetabling (when the solver is running), the best timetable found so far is saved here. It is the timetable that is presented to the user when he/she stops the solver or when the time-out is reached.

When the user interacts and makes changes, he/she can save intermediate results as "Best Timetable Found So Far" and later come back to this timetable if the current one is not good.

Operations are self-descriptive

    • Save

        • Replace the timetable that was loaded originally with this new one

            • Displayed only if a saved timetable was loaded

    • Save As New

        • Save as a new timetable (do not replace the loaded one)

    • Save & Commit

        • Replace the loaded timetable with a new one and commit it

    • Save As New & Commit

        • Save as a new timetable and commit it

Current Timetable

When solver is stopped, the Best Timetable Found So Far is the same as the Current Timetable. From that moment, any manual changes made by the user are applied to the Current Timetable.

Operations

    • Restore From Best

        • Discard the current timetable and start again from the best timetable found so far

    • Save To Best

        • Overwrite the Best Timetable Found So Far with this current timetable (when you consider the current one better and want to store it temporarily)

Problems

The list of warnings appears if any problem occurred during the data load. If there is a problem during solving, there will be an error message (such as Error: FATAL).

Hint: See Solver Warnings to see a detailed list of warnings and errors that may be produced by the solver. If you see a FATAL message, keep the solver in the memory and use Contact Us (located in Help menu) page to report a problem.

Operations

    • Start

        • Restart the solver from the current timetable

    • Student Sectioning

        • Perform student sectioning on the current timetable

    • Reload Input Data

        • Reload the data from the Input Data section without loosing the current time/room assignments in the current timetable; only prohibited assignments will be lost if breaking hard constraints is not allowed

    • Unload

        • Unload both the input data and the timetable from memory (any timetable will be lost unless saved in the Best Timetable Found So Far section or in the Timetables screen)

    • Export Solution

        • Export the current solution as a comma separated values (CSV) file

    • Refresh

        • Refresh this screen