mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-11-04 01:12:08 +01:00 
			
		
		
		
	Merge branch 'wei' into 'main'
More robust algorithm See merge request bde/nk20!337
This commit is contained in:
		@@ -365,7 +365,7 @@ class WEISurvey2025(WEISurvey):
 | 
				
			|||||||
        return sum([cls.get_algorithm_class().get_bus_information(bus).scores[word] for bus in buses]) / buses.count()
 | 
					        return sum([cls.get_algorithm_class().get_bus_information(bus).scores[word] for bus in buses]) / buses.count()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @lru_cache()
 | 
					    @lru_cache()
 | 
				
			||||||
    def score(self, bus):
 | 
					    def score_questions(self, bus):
 | 
				
			||||||
        """
 | 
					        """
 | 
				
			||||||
        The score given by the answers to the questions
 | 
					        The score given by the answers to the questions
 | 
				
			||||||
        """
 | 
					        """
 | 
				
			||||||
@@ -391,7 +391,7 @@ class WEISurvey2025(WEISurvey):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    @lru_cache()
 | 
					    @lru_cache()
 | 
				
			||||||
    def scores_per_bus(self):
 | 
					    def scores_per_bus(self):
 | 
				
			||||||
        return {bus: (self.score(bus), self.score_words(bus)) for bus in self.get_algorithm_class().get_buses()}
 | 
					        return {bus: (self.score_questions(bus), self.score_words(bus)) for bus in self.get_algorithm_class().get_buses()}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @lru_cache()
 | 
					    @lru_cache()
 | 
				
			||||||
    def ordered_buses(self):
 | 
					    def ordered_buses(self):
 | 
				
			||||||
@@ -400,7 +400,6 @@ class WEISurvey2025(WEISurvey):
 | 
				
			|||||||
        """
 | 
					        """
 | 
				
			||||||
        values = list(self.scores_per_bus().items())
 | 
					        values = list(self.scores_per_bus().items())
 | 
				
			||||||
        values.sort(key=lambda item: -item[1][1])
 | 
					        values.sort(key=lambda item: -item[1][1])
 | 
				
			||||||
        values = values[:3]
 | 
					 | 
				
			||||||
        return values
 | 
					        return values
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @classmethod
 | 
					    @classmethod
 | 
				
			||||||
@@ -509,17 +508,17 @@ class WEISurveyAlgorithm2025(WEISurveyAlgorithm):
 | 
				
			|||||||
                else:
 | 
					                else:
 | 
				
			||||||
                    # Current bus has not enough places. Remove the least preferred student from the bus if existing
 | 
					                    # Current bus has not enough places. Remove the least preferred student from the bus if existing
 | 
				
			||||||
                    least_preferred_survey = None
 | 
					                    least_preferred_survey = None
 | 
				
			||||||
                    least_scores = (-1, -1)
 | 
					                    least_score = -1
 | 
				
			||||||
                    # Find the least student in the bus that has a lower score than the current student
 | 
					                    # Find the least student in the bus that has a lower score than the current student
 | 
				
			||||||
                    for survey2 in surveys:
 | 
					                    for survey2 in surveys:
 | 
				
			||||||
                        if not survey2.information.valid or survey2.information.get_selected_bus() != bus:
 | 
					                        if not survey2.information.valid or survey2.information.get_selected_bus() != bus:
 | 
				
			||||||
                            continue
 | 
					                            continue
 | 
				
			||||||
                        scores2 = survey2.score(bus), survey2.score_words(bus)
 | 
					                        score2 = survey2.score_questions(bus)
 | 
				
			||||||
                        if current_scores <= scores2:  # Ignore better students
 | 
					                        if current_scores[0] <= score2:  # Ignore better students
 | 
				
			||||||
                            continue
 | 
					                            continue
 | 
				
			||||||
                        if least_preferred_survey is None or scores2 < least_scores:
 | 
					                        if least_preferred_survey is None or score2 < least_score:
 | 
				
			||||||
                            least_preferred_survey = survey2
 | 
					                            least_preferred_survey = survey2
 | 
				
			||||||
                            least_scores = scores2
 | 
					                            least_score = score2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                    if least_preferred_survey is not None:
 | 
					                    if least_preferred_survey is not None:
 | 
				
			||||||
                        # Remove the least student from the bus and put the current student in.
 | 
					                        # Remove the least student from the bus and put the current student in.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -110,6 +110,6 @@ class TestWEIAlgorithm(TestCase):
 | 
				
			|||||||
            max_score = buses[0][1][0]
 | 
					            max_score = buses[0][1][0]
 | 
				
			||||||
            penalty += (max_score - score) ** 2
 | 
					            penalty += (max_score - score) ** 2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            self.assertLessEqual(max_score - score, 1)  # Always less than 25 % of tolerance
 | 
					            self.assertLessEqual(max_score - score, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.assertLessEqual(penalty / 100, 25)  # Tolerance of 5 %
 | 
					        self.assertLessEqual(penalty / 100, 25)  # Tolerance of 5 %
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user