Sha256: ad6c27c892f3c88868d646f5f8b8c907fd7287c927ad6e3c61dcff9d21247e52

Contents?: true

Size: 1.57 KB

Versions: 17

Compression:

Stored size: 1.57 KB

Contents

# frozen_string_literal: true

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

module SVMKit
  module EvaluationMeasure
    # R2Score is a class that calculates the coefficient of determination for the predicted values.
    #
    # @example
    #   evaluator = SVMKit::EvaluationMeasure::R2Score.new
    #   puts evaluator.score(ground_truth, predicted)
    class R2Score
      include Base::Evaluator

      # Create a new evaluation measure calculater for coefficient of determination.
      def initialize; end

      # Calculate the coefficient of determination.
      #
      # @param y_true [Numo::DFloat] (shape: [n_samples, n_outputs]) Ground truth target values.
      # @param y_pred [Numo::DFloat] (shape: [n_samples, n_outputs]) Estimated taget values.
      # @return [Float] Coefficient of determination
      def score(y_true, y_pred)
        SVMKit::Validation.check_tvalue_array(y_true)
        SVMKit::Validation.check_tvalue_array(y_pred)
        raise ArgumentError, 'Expect to have the same size both y_true and y_pred.' unless y_true.shape == y_pred.shape

        n_samples, n_outputs = y_true.shape
        numerator = ((y_true - y_pred)**2).sum(0)
        yt_mean = y_true.sum(0) / n_samples
        denominator = ((y_true - yt_mean)**2).sum(0)
        if n_outputs.nil?
          denominator.zero? ? 0.0 : 1.0 - numerator / denominator
        else
          scores = 1 - numerator / denominator
          scores[denominator.eq(0)] = 0.0
          scores.sum / scores.size
        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/r2_score.rb
svmkit-0.7.2 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.7.1 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.7.0 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.6.3 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.6.2 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.6.1 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.6.0 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.5.2 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.5.1 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.5.0 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.4.1 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.4.0 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.3.3 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.3.2 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.3.1 lib/svmkit/evaluation_measure/r2_score.rb
svmkit-0.3.0 lib/svmkit/evaluation_measure/r2_score.rb