Module: Rust::EffectSize::CliffDelta

Defined in:
lib/rust-effsize.rb

Class Method Summary collapse

Class Method Details

.compute(d1, d2) ⇒ Object

Raises:

  • (TypeError)


23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/rust-effsize.rb', line 23

def compute(d1, d2)
    raise TypeError, "Expecting Array of numerics" if !d1.is_a?(Array) || !d1.all? { |e| e.is_a?(Numeric) }
    raise TypeError, "Expecting Array of numerics" if !d2.is_a?(Array) || !d2.all? { |e| e.is_a?(Numeric) }
    
    Rust.exclusive do
        Rust['effsize.a'] = d1
        Rust['effsize.b'] = d2
        
        Rust._eval("effsize.result = cliff.delta(effsize.a, effsize.b)")
        
        result = Rust::EffectSize::Result.new
        result.name                 = "Cliff's delta"
        result.estimate             = Rust._pull("effsize.result$estimate")
        result.confidence_interval  = Range.new(*Rust._pull("effsize.result$conf.int"))
        result.confidence_level     = Rust._pull("effsize.result$conf.level")
        result.magnitude            = Rust._pull("as.character(effsize.result$magnitude)").to_sym
        
        return result
    end
end