Sha256: c64c19b1b21e5efd52de7674f2747e6f50f4f4807e1ac7edcc7b2957bff36dfc

Contents?: true

Size: 1.63 KB

Versions: 17

Compression:

Stored size: 1.63 KB

Contents

# frozen_string_literal: true

require 'svmkit/validation'
require 'svmkit/base/evaluator'
require 'svmkit/evaluation_measure/precision_recall'

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

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

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

      # Calculate average precision.
      #
      # @param y_true [Numo::Int32] (shape: [n_samples]) Ground truth labels.
      # @param y_pred [Numo::Int32] (shape: [n_samples]) Predicted labels.
      # @return [Float] Average precision
      def score(y_true, y_pred)
        SVMKit::Validation.check_label_array(y_true)
        SVMKit::Validation.check_label_array(y_pred)

        case @average
        when 'binary'
          precision_each_class(y_true, y_pred).last
        when 'micro'
          micro_average_precision(y_true, y_pred)
        when 'macro'
          macro_average_precision(y_true, y_pred)
        end
      end
    end
  end
end

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
svmkit-0.7.3 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.7.2 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.7.1 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.7.0 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.6.3 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.6.2 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.6.1 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.6.0 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.5.2 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.5.1 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.5.0 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.4.1 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.4.0 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.3.3 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.3.2 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.3.1 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.3.0 lib/svmkit/evaluation_measure/precision.rb