19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
# File 'lib/rust/stats/effsize.rb', line 19
def self.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) }
if d1.size <= 1 || d2.size <= 1
return Rust::EffectSize::Result.new
end
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") rescue Float::NAN
result.confidence_interval = Range.new(*Rust._pull("effsize.result$conf.int")) rescue nil
result.confidence_level = Rust._pull("effsize.result$conf.level") rescue Float::NAN
result.magnitude = Rust._pull("as.character(effsize.result$magnitude)").to_sym rescue nil
return result
end
end
|