diff --git a/pycm/pycm_class_func.py b/pycm/pycm_class_func.py index 06bb6a5c..e1f53449 100644 --- a/pycm/pycm_class_func.py +++ b/pycm/pycm_class_func.py @@ -708,7 +708,7 @@ def basic_statistics(TP, TN, FP, FN): :return: basic statistics as dict """ result = {} - for i in CLASS_PARAMS.keys(): + for i in CLASS_PARAMS: result[i] = {} result["TP"] = TP result["TN"] = TN @@ -736,7 +736,7 @@ def class_statistics(TP, TN, FP, FN, classes, table): :return: classes' statistics as dict """ result = basic_statistics(TP, TN, FP, FN) - for i in TP.keys(): + for i in TP: result["POP"][i] = TP[i] + TN[i] + FP[i] + FN[i] result["P"][i] = TP[i] + FN[i] result["N"][i] = TN[i] + FP[i] diff --git a/pycm/pycm_compare.py b/pycm/pycm_compare.py index de8aecc8..ba9655ea 100644 --- a/pycm/pycm_compare.py +++ b/pycm/pycm_compare.py @@ -154,12 +154,12 @@ def __compare_class_handler__(compare, cm_dict): class_weight_sum = sum(compare.class_weight.values()) class_benchmark_weight_sum = sum(compare.class_benchmark_weight.values()) for c in compare.classes: - for item in CLASS_BENCHMARK_SCORE_DICT.keys(): + for item in CLASS_BENCHMARK_SCORE_DICT: max_item_score = len(CLASS_BENCHMARK_SCORE_DICT[item]) - 1 all_class_score = [CLASS_BENCHMARK_SCORE_DICT[item][ cm.class_stat[item][c]] for cm in cm_dict.values()] if all([isinstance(x, int) for x in all_class_score]): - for cm_name in cm_dict.keys(): + for cm_name in cm_dict: score = (compare.class_weight[c] / class_weight_sum) * ( CLASS_BENCHMARK_SCORE_DICT[item][cm_dict[cm_name].class_stat[item][c]] / max_item_score) score = score * \ @@ -179,12 +179,12 @@ def __compare_overall_handler__(compare, cm_dict): """ overall_benchmark_weight_sum = sum( compare.overall_benchmark_weight.values()) - for item in OVERALL_BENCHMARK_SCORE_DICT.keys(): + for item in OVERALL_BENCHMARK_SCORE_DICT: max_item_score = len(OVERALL_BENCHMARK_SCORE_DICT[item]) - 1 all_overall_score = [OVERALL_BENCHMARK_SCORE_DICT[item][ cm.overall_stat[OVERALL_BENCHMARK_MAP[item]]] for cm in cm_dict.values()] if all([isinstance(x, int) for x in all_overall_score]): - for cm_name in cm_dict.keys(): + for cm_name in cm_dict: score = OVERALL_BENCHMARK_SCORE_DICT[item][cm_dict[cm_name] .overall_stat[OVERALL_BENCHMARK_MAP[item]]] / max_item_score score = score * \ @@ -202,7 +202,7 @@ def __compare_rounder__(compare, cm_dict): :type cm_dict: dict :return: None """ - for cm_name in cm_dict.keys(): + for cm_name in cm_dict: compare.scores[cm_name]["overall"] = numpy.around( compare.scores[cm_name]["overall"], compare.digit) compare.scores[cm_name]["class"] = numpy.around( @@ -263,7 +263,7 @@ def __compare_weight_handler__(compare, weight, weight_type): return None if not isinstance(weight, dict): raise pycmCompareError(error_dict[weight_type]) - if set(weight.keys()) == set(valid_dict[weight_type]): + if set(weight) == set(valid_dict[weight_type]): if all([isfloat(x) for x in weight.values()] ) and sum(weight.values()) != 0: setattr(compare, weight_type, weight) @@ -319,7 +319,7 @@ def __compare_assign_handler__( compare.best_name = None compare.sorted = None compare.scores = {k: {"overall": 0, "class": 0}.copy() - for k in cm_dict.keys()} + for k in cm_dict} __compare_weight_handler__(compare, class_weight, "class_weight") __compare_weight_handler__( compare, diff --git a/pycm/pycm_handler.py b/pycm/pycm_handler.py index 84afcf05..5cd7dfe1 100644 --- a/pycm/pycm_handler.py +++ b/pycm/pycm_handler.py @@ -138,7 +138,7 @@ def __obj_file_handler__(cm, file): loaded_transpose = False cm.transpose = loaded_transpose loaded_matrix = dict(obj_data["Matrix"]) - for i in loaded_matrix.keys(): + for i in loaded_matrix: loaded_matrix[i] = dict(loaded_matrix[i]) matrix_param = matrix_params_from_table(loaded_matrix) cm.digit = obj_data["Digit"] @@ -160,7 +160,7 @@ def __obj_matrix_handler__(matrix, classes, transpose): :return: matrix parameters as list """ if matrix_check(matrix): - if class_check(list(matrix.keys())) is False: + if class_check(list(matrix)) is False: raise pycmMatrixError(MATRIX_CLASS_TYPE_ERROR) matrix_param = matrix_params_from_table(matrix, classes, transpose) else: diff --git a/pycm/pycm_obj.py b/pycm/pycm_obj.py index 58973f4c..b2f0d1eb 100644 --- a/pycm/pycm_obj.py +++ b/pycm/pycm_obj.py @@ -223,7 +223,7 @@ def __iter__(self): :return: None """ - for key in self.matrix.keys(): + for key in self.matrix: yield key, self.matrix[key] def __contains__(self, class_name): @@ -539,7 +539,7 @@ def F_beta(self, beta): """ try: F_dict = {} - for i in self.TP.keys(): + for i in self.TP: F_dict[i] = F_calc( TP=self.TP[i], FP=self.FP[i], @@ -656,13 +656,13 @@ def CI( if isinstance(binom_method, str): method = binom_method.lower() if one_sided: - if alpha in ALPHA_ONE_SIDE_TABLE.keys(): + if alpha in ALPHA_ONE_SIDE_TABLE: CV = ALPHA_ONE_SIDE_TABLE[alpha] else: CV = ALPHA_ONE_SIDE_TABLE[0.05] warn(CI_ALPHA_ONE_SIDE_WARNING, RuntimeWarning) else: - if alpha in ALPHA_TWO_SIDE_TABLE.keys(): + if alpha in ALPHA_TWO_SIDE_TABLE: CV = ALPHA_TWO_SIDE_TABLE[alpha] else: CV = ALPHA_TWO_SIDE_TABLE[0.05] @@ -744,7 +744,7 @@ def relabel(self, mapping, sort=False): """ if not isinstance(mapping, dict): raise pycmMatrixError(MAPPING_FORMAT_ERROR) - if set(self.classes) != set(mapping.keys()): + if set(self.classes) != set(mapping): raise pycmMatrixError(MAPPING_CLASS_NAME_ERROR) if len(self.classes) != len(set(mapping.values())): raise pycmMatrixError(MAPPING_CLASS_NAME_ERROR) @@ -763,7 +763,7 @@ def relabel(self, mapping, sort=False): self.normalized_table = normalized_table_temp self.matrix = self.table self.normalized_matrix = self.normalized_table - for param in self.class_stat.keys(): + for param in self.class_stat: temp_dict = {} for classname in self.classes: temp_dict[mapping[classname] @@ -816,7 +816,7 @@ def weighted_average(self, param, weight=None, none_omit=False): if weight is not None: if not isinstance(weight, dict): raise pycmAverageError(AVERAGE_WEIGHT_ERROR) - if set(weight.keys()) == set(self.classes) and all( + if set(weight) == set(self.classes) and all( [isfloat(x) for x in weight.values()]): selected_weight = weight.copy() else: @@ -828,7 +828,7 @@ def weighted_average(self, param, weight=None, none_omit=False): try: weight_list = [] param_list = [] - for class_name in selected_param.keys(): + for class_name in selected_param: if selected_param[class_name] == "None" and none_omit: continue weight_list.append(selected_weight[class_name]) @@ -849,7 +849,7 @@ def weighted_kappa(self, weight=None): if matrix_check(weight) is False: warn(WEIGHTED_KAPPA_WARNING, RuntimeWarning) return self.Kappa - if set(weight.keys()) != set(self.classes): + if set(weight) != set(self.classes): warn(WEIGHTED_KAPPA_WARNING, RuntimeWarning) return self.Kappa return weighted_kappa_calc( @@ -872,7 +872,7 @@ def weighted_alpha(self, weight=None): if matrix_check(weight) is False: warn(WEIGHTED_ALPHA_WARNING, RuntimeWarning) return self.Alpha - if set(weight.keys()) != set(self.classes): + if set(weight) != set(self.classes): warn(WEIGHTED_ALPHA_WARNING, RuntimeWarning) return self.Alpha return weighted_alpha_calc( @@ -953,7 +953,7 @@ def position(self): if self.predict_vector is None or self.actual_vector is None: raise pycmVectorError(VECTOR_ONLY_ERROR) if self.positions is None: - classes = list(self.label_map.keys()) + classes = list(self.label_map) positions = { self.label_map[_class]: { 'TP': [], diff --git a/pycm/pycm_output.py b/pycm/pycm_output.py index 93451031..274f6e2e 100644 --- a/pycm/pycm_output.py +++ b/pycm/pycm_output.py @@ -55,7 +55,7 @@ def color_check(color): return list(color) if isinstance(color, str): color_lower = color.lower() - if color_lower in TABLE_COLOR.keys(): + if color_lower in TABLE_COLOR: return TABLE_COLOR[color_lower] return [0, 0, 0] @@ -232,7 +232,7 @@ def html_class_stat( str(i) + '\n' result += '