Class: Riffer::Evals::Result

Inherits:
Object
  • Object
show all
Defined in:
lib/riffer/evals/result.rb

Overview

Represents the result of a single evaluation.

Contains the score, reason, and metadata from running an evaluator.

result = Riffer::Evals::Result.new(
  evaluator: "answer_relevancy",
  score: 0.85,
  reason: "The response addresses the question directly.",
  higher_is_better: true
)

result.score           # => 0.85
result.evaluator       # => "answer_relevancy"
result.higher_is_better # => true

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(evaluator:, score:, reason: nil, metadata: {}, higher_is_better: true) ⇒ Result

Initializes a new evaluation result.

Raises Riffer::ArgumentError if score is not between 0.0 and 1.0.

: (evaluator: String, score: Float, ?reason: String?, ?metadata: Hash[Symbol, untyped], ?higher_is_better: bool) -> void



40
41
42
43
44
45
46
47
# File 'lib/riffer/evals/result.rb', line 40

def initialize(evaluator:, score:, reason: nil, metadata: {}, higher_is_better: true)
  @evaluator = evaluator
  @score = score.to_f
  validate_score!
  @reason = reason
  @metadata = 
  @higher_is_better = higher_is_better
end

Instance Attribute Details

#evaluatorObject (readonly)

The identifier of the evaluator that produced this result.



21
22
23
# File 'lib/riffer/evals/result.rb', line 21

def evaluator
  @evaluator
end

#higher_is_betterObject (readonly)

Whether higher scores are better for this evaluator.



33
34
35
# File 'lib/riffer/evals/result.rb', line 33

def higher_is_better
  @higher_is_better
end

#metadataObject (readonly)

Additional metadata from the evaluation.



30
31
32
# File 'lib/riffer/evals/result.rb', line 30

def 
  @metadata
end

#reasonObject (readonly)

Human-readable explanation of the score.



27
28
29
# File 'lib/riffer/evals/result.rb', line 27

def reason
  @reason
end

#scoreObject (readonly)

The evaluation score (0.0 to 1.0).



24
25
26
# File 'lib/riffer/evals/result.rb', line 24

def score
  @score
end

Instance Method Details

#to_hObject

Returns a hash representation of the result.

: () -> Hash[Symbol, untyped]



52
53
54
55
56
57
58
59
60
# File 'lib/riffer/evals/result.rb', line 52

def to_h
  {
    evaluator: evaluator,
    score: score,
    reason: reason,
    metadata: ,
    higher_is_better: higher_is_better
  }
end