Skip to content

alperen21/Curve-Grade-Calculator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Curve Grade Calculator

After I took an introductory course in probability / statistics in my university since I now had learned about normal distribution and curve grades I realized that I now can approximate my rank in the class and could approximate my letter grade given that the instructor provides us with standard deviation, mean and class population. It occured to me that I could use some libraries in Python to utilitze this into a script so I wrote the code for automating the calculations.

Math

Curve class can do two calculations, approximating your rank within the class and calculating the letter grade for the individual coursework/exam (the algorithm assumes that the given coursework makes up 100% of your final / cumulative score). For approximation of the place you are at within the class:

Let's say you got 78% in class that has the mean 37.07, standard deviation 23.2, highest grade is 91 and the lowest grade is 0 and that particular class has 102 students. Then, if the random variable X indicates the score of another student, the probability of that student scoring higher than you would be:

Which is equal to:

I used Scipy library to calculate normal probabilities. table_grade corresponds to Table(1.76), table_min corresponds to Table(-1.59) and table_max corresponds to Table(2.32). If statements are there to also take into account that the normalized grade may fall on the left or the right side of the 0 point of Gaussian curve, which depends on whether your grade is higher or lower than the mean.

This probability is then multiplied with the total number of students in the class to approximate your place in the ranking of the class. For example in this case the output of rank() is 4 which means that you got the 4th highest grade in the whole class.

For the letter grades, a dictionary data structure is used. This dictionary (grade_boundaries) is initialized within initialization of the class itself accordingly to boolean values "default" and "plus_minus" which are set to true by default. If plus_minus is set to true, the class assumes that the instructor is using the grade system like A, A-, B+, B, B- and so on. If its set to false the class will switch to AA, BA, BB grading system. If default is set to true, the grade scale will be divided equally and if not grades list will be used to determine which percentages correspond to which letter grades. For example, A:10 means that only 10% of the class will get an A; if the corresponding A- is set to 15 then someone who falls between 15%-10% will get an A- and so on.

But of course we do not get letter grades from just one exam or homework. The multiCurve class takes this into account which is inherited from the original curve class. multiCurve.init() takes a list of CurveObjects. Each instance of CurveObject corresponds to one exam / homework / etc and each instance of CurveObject naturally has it's own mean and standard deviation. What multiCurve does is that it treats every CurveObject as a random variable. The total grade of the random student is a distinct random variable which is the sum of all CurveObject random variables multiplied with their corresponding weights (I am assuming the sum of all weights is equal to 1). Inside init the class calculates the mean of this new random variable using properties of linear operators and utilizes the exact same thing to calculate variance and then convert it to standard deviation. For example if the students take one midterm and one final with corresponding weights of 40% and 60%, then the new random variable will be:

Then the multiCurve class plugs thse new variables to the functions of the base class (curve class) and since from the point of view of the base class Y is a singular random variable with its own mean and standard deviation, it works.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published