Sha256: 7ac2d74270d1c93c2a826a48935cab101c25535162bc40b320c6e8c9e54cc515

Contents?: true

Size: 1.6 KB

Versions: 2

Compression:

Stored size: 1.6 KB

Contents

# frozen_string_literal: true

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

      # Claculate 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

2 entries across 2 versions & 1 rubygems

Version Path
svmkit-0.2.9 lib/svmkit/evaluation_measure/precision.rb
svmkit-0.2.8 lib/svmkit/evaluation_measure/precision.rb