Skip to content

Commit

Permalink
feat: increase grading rounding precision
Browse files Browse the repository at this point in the history
Enabling the rounding in #16837 has been causing noticeable (up to 1 percentage point) differences between non-rounded subsection grades and a total grade for a course. This increases the grade precision to reduce the negative implications of double rounding.
  • Loading branch information
Agrendalath committed Nov 8, 2021
1 parent cfe75e9 commit 16b88f9
Show file tree
Hide file tree
Showing 5 changed files with 16 additions and 16 deletions.
6 changes: 3 additions & 3 deletions common/lib/xmodule/xmodule/graders.py
Original file line number Diff line number Diff line change
Expand Up @@ -387,7 +387,7 @@ def grade(self, grade_sheet, generate_random_scores=False):
section_name = scores[i].display_name

percentage = scores[i].percent_graded
summary_format = "{section_type} {index} - {name} - {percent:.0%} ({earned:.3n}/{possible:.3n})"
summary_format = "{section_type} {index} - {name} - {percent:.2%} ({earned:.3n}/{possible:.3n})"
summary = summary_format.format(
index=i + self.starting_index,
section_type=self.section_type,
Expand Down Expand Up @@ -421,7 +421,7 @@ def grade(self, grade_sheet, generate_random_scores=False):
if len(breakdown) == 1:
# if there is only one entry in a section, suppress the existing individual entry and the average,
# and just display a single entry for the section.
total_detail = "{section_type} = {percent:.0%}".format(
total_detail = "{section_type} = {percent:.2%}".format(
percent=total_percent,
section_type=self.section_type,
)
Expand All @@ -430,7 +430,7 @@ def grade(self, grade_sheet, generate_random_scores=False):
'detail': total_detail, 'category': self.category, 'prominent': True}, ]
else:
# Translators: "Homework Average = 0%"
total_detail = _("{section_type} Average = {percent:.0%}").format(
total_detail = _("{section_type} Average = {percent:.2%}").format(
percent=total_percent,
section_type=self.section_type
)
Expand Down
12 changes: 6 additions & 6 deletions common/test/acceptance/tests/lms/test_progress_page.py
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,7 @@ def test_axis_a11y(self):
assert ['0%', 'true'] == self.progress_page.y_tick_label(1)
assert ['Pass 50%', 'true'] == self.progress_page.y_tick_label(2)
# Verify x-Axis labels and sr-text
self._check_tick_text(0, ['Homework 1 - Test Subsection 1 - 50% (1/2)'], 'HW 01')
self._check_tick_text(0, ['Homework 1 - Test Subsection 1 - 50.00% (1/2)'], 'HW 01')

# Homeworks 2-10 are checked in the for loop below.

Expand All @@ -209,8 +209,8 @@ def test_axis_a11y(self):
'HW 12'
)

self._check_tick_text(12, ['Homework Average = 5%'], 'HW Avg')
self._check_tick_text(13, ['Lab 1 - Lab Subsection - 100% (1/1)'], 'Lab 01')
self._check_tick_text(12, ['Homework Average = 5.00%'], 'HW Avg')
self._check_tick_text(13, ['Lab 1 - Lab Subsection - 100.00% (1/1)'], 'Lab 01')

# Labs 2-10 are checked in the for loop below.

Expand All @@ -225,9 +225,9 @@ def test_axis_a11y(self):
'Lab 12'
)

self._check_tick_text(25, ['Lab Average = 10%'], 'Lab Avg')
self._check_tick_text(26, ['Midterm Exam = 0%'], 'Midterm')
self._check_tick_text(27, ['Final Exam = 0%'], 'Final')
self._check_tick_text(25, ['Lab Average = 10.00%'], 'Lab Avg')
self._check_tick_text(26, ['Midterm Exam = 0.00%'], 'Midterm')
self._check_tick_text(27, ['Final Exam = 0.00%'], 'Final')

self._check_tick_text(
28,
Expand Down
4 changes: 2 additions & 2 deletions lms/djangoapps/grades/scores.py
Original file line number Diff line number Diff line change
Expand Up @@ -162,8 +162,8 @@ def compute_percent(earned, possible):
Returns the percentage of the given earned and possible values.
"""
if possible > 0:
# Rounds to two decimal places.
return around(earned / possible, decimals=2)
# Rounds to four decimal places.
return around(earned / possible, decimals=4)
else:
return 0.0

Expand Down
8 changes: 4 additions & 4 deletions lms/djangoapps/grades/tests/test_course_grade_factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -215,26 +215,26 @@ def test_course_grade_summary(self):
'section_breakdown': [
{
'category': 'Homework',
'detail': 'Homework 1 - Test Sequential X with an & Ampersand - 50% (1/2)',
'detail': 'Homework 1 - Test Sequential X with an & Ampersand - 50.00% (1/2)',
'label': 'HW 01',
'percent': 0.5
},
{
'category': 'Homework',
'detail': 'Homework 2 - Test Sequential A - 0% (0/1)',
'detail': 'Homework 2 - Test Sequential A - 0.00% (0/1)',
'label': 'HW 02',
'percent': 0.0
},
{
'category': 'Homework',
'detail': 'Homework Average = 25%',
'detail': 'Homework Average = 25.00%',
'label': 'HW Avg',
'percent': 0.25,
'prominent': True
},
{
'category': 'NoCredit',
'detail': 'NoCredit Average = 0%',
'detail': 'NoCredit Average = 0.00%',
'label': 'NC Avg',
'percent': 0,
'prominent': True
Expand Down
2 changes: 1 addition & 1 deletion lms/djangoapps/grades/tests/test_subsection_grade.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
@ddt
class SubsectionGradeTest(GradeTestBase): # lint-amnesty, pylint: disable=missing-class-docstring

@data((50, 100, .50), (59.49, 100, .59), (59.51, 100, .60), (59.50, 100, .60), (60.5, 100, .60))
@data((50, 100, .5), (.5949, 100, .0059), (.5951, 100, .006), (.595, 100, .0059), (.605, 100, .006))
@unpack
def test_create_and_read(self, mock_earned, mock_possible, expected_result):
with mock_get_score(mock_earned, mock_possible):
Expand Down

0 comments on commit 16b88f9

Please sign in to comment.