Sha256: 1f2ef832c243b6b9a1dd882a6f4b6fba00f76a3edbdb07d585eb1e15f556ffc9

Contents?: true

Size: 1.55 KB

Versions: 40

Compression:

Stored size: 1.55 KB

Contents

# frozen_string_literal: true

require 'rumale/base/evaluator'
require 'rumale/evaluation_measure/precision_recall'

module Rumale
  # This module consists of the classes for model evaluation.
  module EvaluationMeasure
    # FScore is a class that calculates the F1-score of the predicted labels.
    #
    # @example
    #   evaluator = Rumale::EvaluationMeasure::FScore.new
    #   puts evaluator.score(ground_truth, predicted)
    class FScore
      include Base::Evaluator
      include EvaluationMeasure::PrecisionRecall

      # Return the average type for calculation of F1-score.
      # @return [String] ('binary', 'micro', 'macro')
      attr_reader :average

      # Create a new evaluation measure calculater for F1-score.
      #
      # @param average [String] The average type ('binary', 'micro', 'macro')
      def initialize(average: 'binary')
        check_params_string(average: average)
        @average = average
      end

      # Calculate average F1-score
      #
      # @param y_true [Numo::Int32] (shape: [n_samples]) Ground truth labels.
      # @param y_pred [Numo::Int32] (shape: [n_samples]) Predicted labels.
      # @return [Float] Average F1-score
      def score(y_true, y_pred)
        y_true = check_convert_label_array(y_true)
        y_pred = check_convert_label_array(y_pred)

        case @average
        when 'binary'
          f_score_each_class(y_true, y_pred).last
        when 'micro'
          micro_average_f_score(y_true, y_pred)
        when 'macro'
          macro_average_f_score(y_true, y_pred)
        end
      end
    end
  end
end

Version data entries

40 entries across 40 versions & 1 rubygems

Version Path
rumale-0.23.3 lib/rumale/evaluation_measure/f_score.rb
rumale-0.23.2 lib/rumale/evaluation_measure/f_score.rb
rumale-0.23.1 lib/rumale/evaluation_measure/f_score.rb
rumale-0.23.0 lib/rumale/evaluation_measure/f_score.rb
rumale-0.22.5 lib/rumale/evaluation_measure/f_score.rb
rumale-0.22.4 lib/rumale/evaluation_measure/f_score.rb
rumale-0.22.3 lib/rumale/evaluation_measure/f_score.rb
rumale-0.22.2 lib/rumale/evaluation_measure/f_score.rb
rumale-0.22.1 lib/rumale/evaluation_measure/f_score.rb
rumale-0.22.0 lib/rumale/evaluation_measure/f_score.rb
rumale-0.21.0 lib/rumale/evaluation_measure/f_score.rb
rumale-0.20.3 lib/rumale/evaluation_measure/f_score.rb
rumale-0.20.2 lib/rumale/evaluation_measure/f_score.rb
rumale-0.20.1 lib/rumale/evaluation_measure/f_score.rb
rumale-0.20.0 lib/rumale/evaluation_measure/f_score.rb
rumale-0.19.3 lib/rumale/evaluation_measure/f_score.rb
rumale-0.19.2 lib/rumale/evaluation_measure/f_score.rb
rumale-0.19.1 lib/rumale/evaluation_measure/f_score.rb
rumale-0.19.0 lib/rumale/evaluation_measure/f_score.rb
rumale-0.18.7 lib/rumale/evaluation_measure/f_score.rb