How to compute precision,recall and f1 score of an imbalanced dataset for K fold cross validation with 10 folds in python

后端 未结 1 1983
不思量自难忘°
不思量自难忘° 2021-02-02 03:20

I have an imbalanced dataset containing binary classification problem.I have built Random Forest Classifier and used k fold cross validation with 10 folds.

kfold         


        
1条回答
  •  囚心锁ツ
    2021-02-02 03:41

    When you use cross_val_score method, you can specify, which scorings you can calculate on each fold:

    from sklearn.metrics import make_scorer, accuracy_score, precision_score, recall_score, f1_score
    
    scoring = {'accuracy' : make_scorer(accuracy_score), 
               'precision' : make_scorer(precision_score),
               'recall' : make_scorer(recall_score), 
               'f1_score' : make_scorer(f1_score)}
    
    kfold = model_selection.KFold(n_splits=10, random_state=42)
    model=RandomForestClassifier(n_estimators=50) 
    
    results = model_selection.cross_val_score(estimator=model,
                                              X=features,
                                              y=labels,
                                              cv=kfold,
                                              scoring=scoring)
    

    After cross validation, you will get results dictionary with keys: 'accuracy', 'precision', 'recall', 'f1_score', which store metrics values on each fold for certain metric. For each metric you can calculate mean and std value by using np.mean(results[value]) and np.std(results[value]), where value - one of your specified metric name.

    0 讨论(0)
提交回复
热议问题