Solver
From UniTimeWiki
Contents |
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
- Configuration - see Solver Configurations for more information
- 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 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
- Refresh this screen
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)
- Reload input data while keeping the current timetable
- 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
- Replace the timetable that was loaded originally with this new one
- 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).
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
Back to Timetabling Documentation.

