-
Notifications
You must be signed in to change notification settings - Fork 303
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cancelled Tutorials in Average Attendance Calculation #10136
Comments
I think cancelled sessions should be canceled in Artemis. I thought we have a feature for it to exclude sessions on public holidays |
You are not supposed to enter 0 then |
I marked them as cancelled and did not enter any number for those. However, Artemis marks them with 0 and includes in the average. |
From a Quick Look at the source code, the following code in /**
* Sets the averageAttendance transient field of the given tutorial group
* <p>
* Calculation:
* <ul>
* <li>Get set of the last three completed sessions (or less than three if not more available)</li>
* <li>Remove sessions without attendance data (null) from the set</li>
* <li>If set is empty, set attendance average of tutorial group to null (meaning could not be determined)</li>
* <li>If set is non empty, set the attendance average of the tutorial group to the arithmetic mean (rounded to integer)</li>
* </ul>
*
* @param tutorialGroup the tutorial group to set the averageAttendance for
*/
private void setAverageAttendance(TutorialGroup tutorialGroup) {
Collection<TutorialGroupSession> sessions;
if (getPersistenceUtil().isLoaded(tutorialGroup, "tutorialGroupSessions") && tutorialGroup.getTutorialGroupSessions() != null) {
sessions = tutorialGroup.getTutorialGroupSessions();
}
else {
sessions = tutorialGroupSessionRepository.findAllByTutorialGroupId(tutorialGroup.getId());
}
sessions.stream()
.filter(tutorialGroupSession -> TutorialGroupSessionStatus.ACTIVE.equals(tutorialGroupSession.getStatus())
&& tutorialGroupSession.getEnd().isBefore(ZonedDateTime.now()))
.sorted(Comparator.comparing(TutorialGroupSession::getStart).reversed()).limit(3)
.map(tutorialGroupSession -> Optional.ofNullable(tutorialGroupSession.getAttendanceCount())).flatMap(Optional::stream).mapToInt(attendance -> attendance).average()
.ifPresentOrElse(value -> tutorialGroup.setAverageAttendance((int) Math.round(value)), () -> tutorialGroup.setAverageAttendance(null));
} This seems to already take cancelled Sessions into account. |
However, from the Screenshot one would expect the average attendance to be 25 instead of 23. Session 1: attendance 25 |
I think I found the bug: (25 + 9 + 34) / 3 = 22,667. This then probably gets rounded up because we are converting it to While there is probably a cleaner solution, something along the lines of this should do the trick: // code...
sessions.stream()
.filter(tutorialGroupSession -> tutorialGroupSession.getEnd().isBefore(ZonedDateTime.now()))
.sorted(Comparator.comparing(TutorialGroupSession::getStart).reversed())
.limit(3)
.toList()
.stream()
.filter(tutorialGroupSession -> TutorialGroupSessionStatus.ACTIVE.equals(tutorialGroupSession.getStatus()))
.map(tutorialGroupSession -> Optional.ofNullable(tutorialGroupSession.getAttendanceCount())).flatMap(Optional::stream).mapToInt(attendance -> attendance).average()
.ifPresentOrElse(value -> tutorialGroup.setAverageAttendance((int) Math.round(value)), () -> tutorialGroup.setAverageAttendance(null)); |
This corresponds to the expected behaviour. Thanks for clarifying. |
This should still be a bug tho. The PR should be easy, feel free to contribute 😄 |
I would like to. This will be my first contribution. I have already set up the project in local with some tweaking. I need help on a couple of things like how to get an account to login. Thanks in advance! |
You can just assign yourself and start working on it. Make sure to read the guides and, more importantly, the guidelines for contributing. |
Describe the bug
Currently, Artemis includes cancelled tutorials in the average attendance calculation for a specific tutorial group. This can lead to misleading statistics, particularly for groups frequently affected by public holidays. The inclusion of cancelled sessions skews the average attendance, making it less reflective of the actual participation in attended sessions.
To Reproduce
Expected behavior
Cancelled tutorials should not be factored into the average attendance calculation. Only tutorials that have taken place and have recorded attendance should contribute to the average.
Screenshots
Which version of Artemis are you seeing the problem on?
7.8.3
What browsers are you seeing the problem on?
Other (specify in "Additional context")
Additional context
Browser: Arc
Relevant log output
No response
The text was updated successfully, but these errors were encountered: