Skip to content

UniTime 4.1 build 99 (Alpha 3)

Pre-release
Pre-release
Compare
Choose a tag to compare
@tomas-muller tomas-muller released this 30 Oct 18:19
· 3236 commits to master since this release

Changes from UniTime 4.1.94, Alpha 2

Scripts: Scripts in progress

  • Scripts in progress table: allow word wrapping in the table (rather than making the page way too wide, e.g., when status lists an exception)

Batch Student Scheduling: Student Filter

  • added ability to filter what student will get loaded into the batch student scheduling solver using a boolean query (solver parameter Load.StudentQuery)

API: Error Handling

  • added ability to return the exception in a JSON format (instead of the default tomcat's error page)

iCalendar Exports

  • ensure that the exported dates are in the local timezone
  • this fixes the issue with daylight savings that was introduced in commit 592152d

API: Room Pictures

  • added ability to retrieve, upload, and delete room pictures
  • retrieve: GET UniTime/api/rooms?pictureId=
  • upload: PUT UniTime/api/rooms?term=&room= (with the file as payload)
  • delete: DELETE UniTime/api/rooms?pictureId=

Application Properties: Temp Files

  • always use US locale for the temp file time stamps (this is to avoid potential issues with accented characters in file names)

API: Rooms

  • added ability to create, update and delete rooms
  • create or update: POST UniTime/api/rooms (with a file in the RoomDetailInterface format as payload)
  • delete: DELETE UniTime/api/rooms?roomId= or DELETE UniTime/api/rooms?term=&room=

Online Student Scheduling: check for new servers

  • do not fail the thread that is periodically checking for new online student scheduling servers to start when the first execution is done at a time when Hibernate is not yet configured (a very rare possibility)

Full Release Notes

Course Timetabling

Class Duration Types

  • Added ability to define different ways how class duration is entered and used in the system (to
    extend the formal Minutes per Week selection).
  • There is a new page (Administration > Other > Class Duration Types), where the class duration
    types can be managed.
    • Permission ClassDurationTypes is needed to access the page, ClassDurationTypeEdit is needed to
      make changes.
  • Default duration type can be defined on an academic session, it can be overridden on the
    instructional offering configuration level (Instructional Offering Configuration page).
    • Name of the default duration type is used in the column headers (Classes, Instructional
      Offerings), abbreviation is used to suffix durations that are using a non-default duration
      type.
  • Following class duration types have been implemented:
    • Minutes per Week (default): this is the existing behaviour (minutes per week == number of
      meetings x minutes per meeting)
    • Average Weekly Mintes: average number of minutes a class takes during a week (weekly minutes =
      number of meetings x minutes per meeting x number of weeks of the data pattern / number of
      weeks in the term)
      • Paramter: number of weeks in the term (defaults to the number of weeks of the default date
        pattern)
    • Semester Minutes: number of minutes in the semester (semester minutes == number of meetings x
      minutes per meeting x number of weeks of the data pattern)
    • Semester Hours: number of hours in the semester (semester hours == number of meetings x
      minutes per meeting x number of weeks of the data pattern / minutes in an hour)
      • Paramter: number of minutes in an hour (defaults to 50)
    • Meetings Minutes: number of minutes of all the meetings, excluding vacations (meeting minutes
      == number of meetings based on the date pattern x minutes per meeting)
      • Parameters: allowed variation of the meeting minutes, expressed as lower and upper bound
        (defaults to 0.95,1.10 -- meaning a class can have 5% less time, combinations with 10% more
        time will be also considered).
      • If the number of meetings based on the date pattern exceeds the desired number of meeting
        minutes, only meetings covering the given number of meeting minutes are created.
    • Meeting Hours: just like meeting minutes, but with hours (semester hours == number of meetings
      based on the date pattern x minutes per meeting / minutes in an hour)
      • Paramters: number of minutes in an hour and the allowed variation of the meeting minutes
        (defaults to 50,0.95,1.10 -- 50 minutes in an hour, 5% less time allowed, combinations with
        up to 10% excess time are considered).
  • It is possible to hide class duration types that are not to be used by the users.
    • If only one type is visible, there is no selection of the class duration type on the
      Instructional Offering Configuration page.

Cancelled Classes

  • Added ability to cancel a class.
  • Multiple Class Setup page: class with enrolments cannot be deleted, but it could be cancelled
    instead.
  • Cancelled classes retain their committed assignment, but the appropriate class event is
    cancelled.
  • Cancelled classes are not loaded into the course timetabling solver.
  • Cancelled classes cannot be edited or re-assigned and they do not block the room or instructor.
  • When a cancelled classes is reopened, the appropriate event is also re-approved.
    • This could cause conflicts, that have to be manually resolved.
  • In student scheduling, cancelled classes are avoided (no valid enrollment can contain
    a cancelled class).
  • In online student scheduling, it is possible to keep existing students in cancelled classes when
    solver configuration parameter named Enrollment.CanKeepCancelledClass is set to true (defaults
    to false).
  • New permissions:
    • Class Delete: ability to delete a class (class cannot be deleted when there is a committed
      solution and at least one student enrolled in the class)
    • Class Delete No Enrollment Check: this permission overrides the enrollment check from the
      Class Delete permission (not given to any role by default)
    • Class Cancel: ability to cancel a class (there must be a committed solution)
    • The Class Delete and Class Cancel permissions are by default given to all roles that have
      Multiple Class Setup Class and / or Class Edit permissions.
  • Added a new permission (named Class Delete No Enrollment Check) that overrides the enrollment
    check from the Class Delete permission.
    • No role is given this permission by default.
  • Make Not-Offered: It is allowed to make an offering not-offered only when there are no students
    enrolled, there is no committed solution, or the user has the Class Delete No Enrollment Check
    permission.
  • Cross Lists: it is allowed to remove a cross-listed course from an offering only when there are
    no students enrolled, there is no committed solution, or the user has the Class Delete No
    Enrollment Check permission.

Conficting Classes

  • Class Detail: Display conflicting classes.
    • There is a new table called Conflicting Classes, just below the Timetable section.
    • The table is only visible when the class is conflicting with some other class (or classes).
    • The same checking as on the Class Assignment page is used.
  • Instructional Offering Detail: Highlight conflicting classes with light red background.
    • Conflicting classes are listed in the tooltip (more details are provided on the Class Detail
      page, see above).
  • Conflict checking: avoid showing conflicts between classes that can overlap because of the Can
    Share Room or the Meet Together distribution.

Instructional Methods

  • Added instructional methods lookup table. Each method has a reference and a label.
  • Example instructional methods: Online, Hybrid, or Face-to-Face.
  • Instructional offering configuration can have an instructional method set.
  • If set, instructional method appear on various pages, including the Scheduling Assistant and
    Events.
  • It is usually included in the Type column, next to the instructional type, e.g., Lecture
    (Online).

Multiple-Major Curricula

  • A curriculum has a new property named multiple majors (boolean, default to false).
  • If a curriculum is marked as multiple-major: a student meets the curriculum only when he/she has
    all the selected majors (not one of the selected).
  • A multiple-major curriculum will inherit course projections from curricula that have no or one
    of the matching majors.
  • There can be multiple curricula that get combined together to form a multiple-major curriculum.
  • If a course is on several curricula, the highest percent share (of the particular
    classification) will be used.
  • These shares can be overridden on the multiple-major curriculum, but no courses can be deleted
    (course projection must be set to zero instead).
  • The parent (single or no major curricula) can have zero requested students, only acting as
    templates for the multiple-major curricula.
  • If there is no multiple-major curriculum, everything works like before.

Reservations

  • Remember last sort in the reservation cookie.
  • Added Previous / Next buttons (Edit Reservation).
  • Added confirmation message when deleting a reservation (Edit Reservation).

Rooms

Overview

  • The room pages have been completely rewritten using the Google Web Toolkit.
  • The new pages are localizable, they are using the same Room Filter as is used in the event
    management, and they are allowing a change to propagate over to the future academic sessions as
    well.
  • It is also possible for users that are not managers in UniTime (e.g., instructors) and/or that
    have no relation to a particular department (e.g., students) to be allowed to use the new rooms
    pages.
  • When accessed from the Events menu, the Rooms, Room Groups and Room Features pages contain the
    selection of an academic session, just like the Events page.
  • It is possible to use the old pages by setting the application property unitime.legacy.rooms to
    true (defaults to false).

Rooms

  • The Rooms page now contains a Room Filter and a table with many features.
  • The table of rooms can be sorted by a given column, can show pretty much any room property, and
    it can be exported to PDF or CSV.

Add/Edit Room

  • Add Room and Edit Room page now contains all the functionality of the various edit pages that
    were accessible from the Room Detail page.
  • Moreover, it is now possible to make the update the room in the (selected) future academic
    sessions as well.
  • Only selected groups of properties can be updated in a particular future session.

Edit Room Departments

  • The page can be used to assign multiple rooms to a particular department or examination
    problem).
  • The page is only accessible when a department or an examination problem is selected in the Room
    Filter.
  • The page is now using the same table of rooms as the Rooms page and it is populated by all the
    rooms matching the Room Filter (except of the selected department / examination problem).
  • Rooms not matching the Room Filter are left unchanged.

Room Groups / Features

  • The Room Groups and Room Features pages also use the Room Filter to list rooms (and matching
    room features and groups).
  • The Add and Edit pages are also using the same table as on the Rooms page with the list of rooms
    populated by all the rooms matching the Room Filter.
  • Rooms not matching the Room Filter are left unchanged.
  • When creating / updated a room group or feature, it is possible to select one or more future
    academic sessions that would be updated as well.
    • Besides of the properties of the group (or feature) like name, abbreviation department, etc.,
      only rooms with a change are updated.
    • This means that the future group (or feature) is NOT reset to the rooms that are currently
      selected on the group (or feature).

Examination Timetabling

Examination Status

  • Added ability to set examination status individually for each examination type.
    • This examination status, if set, overrides the academic session status (for all users).
    • Examination statues can be defined on the Administration > Other > Status Types page (Apply:
      Examinations).
    • The following statuses are created by default: Examination Disabled, Examination Data Entry,
      Examination Timetabling, and Examination Published.
    • Examination statuses can be set on the Administration > Academic Sessions > Examination
      Statuses page.
  • This allows for each examination problem to be viewed, edited, timetabled, and published at
    a different time.
  • It is also possible to attach examination managers to each examination type (for the current
    academic session).
    • If this relation is defined, only the selected manager(s) can view, edit, or timetable the
      given examination problem (based on the status).
    • If this relation is NOT defined, all examination managers can view, edit, or timetable all
      examination problems.
    • This relation is also to be edited on the Administration > Academic Sessions > Examination
      Statuses page.
    • Only managers with a role that is academic session dependent and that allows to access the
      examination solver are listed.

Data Exchange

  • Course Offering Export: More examination properties are now included (print offset, length,
    etc.).
  • Course Offering Import: Added ability to import examinations together with the offerings
    (including period and room assignments).

Batch Student Scheduling

Minimal Perturbation Mode

  • In priority and equal weighting, the difference of an enrollment (from the initial one) is
    computed as an average using the following schema:
    • an initial section counts as 1
    • same choice section counts as 0.9 (parameter StudentWeights.SameChoice)
    • same time section counts as 0.7 (parameter StudentWeights.SameTime)
    • different time section counts as 0
  • Non-initial enrollment weight is penalized with weight StudentWeights.Perturbation (defaults to
    0.100).
  • When MPP is enabled, solution info contains the following three new properties:
    • Perturbations: same section assigned (% of initial section assigned over all course requests
      with initial enrollment)
    • Perturbations: same choice assigned (% of same time and instructor section assigned over all
      course requests with initial enrollment)
    • Perturbations: same time assigned (% of same time section assigned over all course requests
      with initial enrollment)
  • When Sectioning.KeepInitialAssignments is set to true (defaults to false), only the initial
    value is in the variable’s domain (when there is an initial value).
    • Also there is a new global constraint (named FixInitialAssignments) that prevents unassignment
      of an initial value by another global constraint (limits, reservations).

Request Groups

  • Added ability to keep students of the same group together.
  • Measured as an average probability of two students (of a group) that are requesting the same
    course being given the same section (of the same subpart).
  • There is a new weight (named StudentWeights.SameGroup, defaults to 0.1) expressing how much this
    criterion affects the student weight (in both priority and equal weighting).
    • This means that if a student is being enrolled into a completely different section, weight of
      such an enrollment is decreased by 10% (the metric reflects how much are the students spread
      between the sections of the course).
  • There is a new Request Groups report on the Student Scheduling Solver Reports page.
  • Request groups are loaded in only when the solver parameter Load.RequestGroups is set to true,
    default is false

Interactive Changes

  • Added ability to use the Scheduling Assistant page to make changes in a student's schedule
    (current solution).
  • It is also possible to change input data (course and free time requests of a student).
    • This possibility can be disabled by setting the solver configuration parameter
      Interactive.UpdateCourseRequests to false (defaults to true).

Student Filter

  • Added ability to filter what student will get loaded into the batch student scheduling solver
    using a boolean query.
  • Solver parameter Load.StudentQuery, when set each student must match the query to be loaded in.
    • Students not matching the query would only count agains the limits, just like with the
      no-batch status.
    • The parameter could be used together with the no-batch student status (both filters will apply
      in such a case).
  • Available query terms (similar to the Filter of the Student Dashboard):
    • status (reference of the student status)
    • area (abbreviation of the academic area)
    • major (code of the academic major)
    • clasf or classification (code of the academic classification)
    • group (code of the student group)
    • accommodation (code of the student accomodation)
    • student (external id of the student)
  • Examples:
    • group:G1 or group:G2
      • Only students of groups G1 and G2 will get loaded in.
    • area:A and (major:M1 or major:M2)
      • Only student of area A and major M1 or M2 will get loaded in.
    • status:Batch
      • Only students of Batch status will get loaded in.

Online Student Scheduling

Online Student Scheduling Dashboard

  • Added ability to use the Online Student Scheduling Dashboard page during the registration phase
    (Course Requests page is available to students).
  • This is done by leveraging the DatabaseServer (version of the online scheduling server that does
    not keep any data in memory).

Custom Interfaces

  • Added ability to use automated wait-listing together with the student enrollment provider
    interface.
  • Added ability to load course requests from an external system when there are none in UniTime
    (for a student).

Other Improvements

iCalendar Queries

  • Automatically hash calendar queries to make the iCalendar URLs much shorter.
    • This is to overcome the 256 character limit on a subscribed calendar URL in Google Calendar.
  • Hashed queries are persisted in UniTime and they are automatically removed if not used for 92
    days (can be changed by unitime.cleanup.hashedQueries property).
  • This feature can be disabled by setting the application property unitime.encode.hash to false.

Student Group Timetable

  • On the Events Timetable page, it is now possible to select a student group.
  • If a student group is selected, all classes / exams, and course-related events of students of
    the selected student group are displayed.
  • It is possible to hide some events by defining a minimal enrollment parameter (see below).
  • Parameters:
    • unitime.events.group.minimalEnrollment
      • Minimal enrollment for a class event to appear in the results (given as % of the group size
        or as an absolute number).
      • For instance, set it to 5 (only classes with at least 5 students of the group are shown) or
        to 10% (limit is 10% of the number of students in the group).
    • unitime.events.group.showGroupEnrollment
      • On the Events / Timetable page, count the enrollments only within the group (may be slow).
      • If set to true, enrollment field shows the number of students of the group enrolled in the
        class / exam / course related event (default is false).
    • GwtConstants: timeGridStudentGroupDoesNotOverlap
      • If true, it is assumed that there are no overlaps in the events of the group — the display
        is like on the personal timetable or when a single week / room is selected (defaults to
        false).
      • This property needs to be set in the
        JavaSource/org/unitime/timetable/gwt/resources/GwtConstants.properties before the build.

Poeple Lookup dialog

  • Added individual lookup permissions to be able to filter what sources can be searched (by a user
    of the given role).
  • The following permissions were added:
    • Can Lookup Students (search student table)
    • Can Lookup Instructor (search departmental_instructor table)
    • Can Lookup Staff (search staff table)
    • Can Lookup Managers (search timetable_manager table)
    • Can Lookup Event Contacts (search event_contact table)
    • Can Lookup Ldap (query LDAP directory, if configured)
  • By default, all roles that can use the People Lookup dialog can search through all the sources.
  • On the personal schedule (event management), if another person is looked up, the new permissions
    are also used to filter the role:
    • Can Lookup Students is needed for the Student role (person is enrolled in a class, an exam, or
      a course related event as a student).
    • Can Lookup Instructors is needed for the Instructor and Coordinator roles (person is assigned
      to a class or an exam as an instructor or coordinator).
    • Can Lookup Event Contacts is needd for the Contact role (person is listed among contacts of
      the event).

UniTime RESTful API

  • UniTime now offers a number of RESTful APIs (many of which have been merged back to UniTime 3.5
    and 4.0), using JSON messages.
  • Most APIs are for getting data out of UniTime, but there are a few exceptions.
  • Following conntectors have been created so far: (including UniTime 3.5 and 4.0)
    • /api/events: ability to retrieve events (using the EventInterface class converted to JSON,
      example: GET UniTime/api/events?type=PERSON&ext=1001&term=Fal2010)
    • /api/json: JSON interface for GWT calls (that implement the GwtRpcRequest interface)
    • /api/exchange: to export/import UniTime's data exchange XML files
      • export example: GET UniTime/api/exchange?term=Fal2010&type=students
      • import example: POST UniTime/api/exchange (with the XML as payload)
    • /api/roles?id= returns a list of academic sessions (and roles) for a person
      (returns a list of academic sessions when there is no id parameter)
    • /api/enrollments?eventId= returns student enrollments for an event, a class (when classId
      parameter is used instead), an exam (examId), a course offering (courseId), an instructional
      offering (offeringId), or instructional offering configuration (configId)
    • /api/instructor-schedule?id=&term= returns classes, courses, and
      examinations assigned to an instructor.
    • /api/class-info?classId= returns information about a class (including assinged instructors
      and coordinators)
  • Following conntectors are only available in UniTime 4.1:
    • /api/rooms: ability to retrieve rooms (using RoomDetailInterface class converted to JSON,
      example GET UniTime/api/rooms?r:building=EDUC)
      • The rooms API can be also used to create, update and delete rooms and to retrieve, upload
        and delete room pictures.
    • /api/sectioning: online student scheduling api (covering all functionality of the
      SectioningService)
      • The SectioningService is used by the Online Student Scheduling Assistant and the Online
        Student Scheduling Dashboard pages.
      • Example: POST UniTime/api/sectioning?term=Fal2010&studentId=1001&operation=section (with the
        payload containing course requests and optionally the previous student schedule).
  • Each connector has the appropriate permission (see Api... permissions), with the ability to
    either use HTTP-simple authentication or an API token.
  • It is possible to change the hibernate cache mode for a particular API connector by setting the
    unitime.api.X.cacheMode application property (where X is the connector name).
    • For example, setting unitime.api.enrollments.cacheMode=REFRESH will make the /api/enrollments
      connector to never read the hibernate cache, but it will keep it updated.