Sha256: e48fb31c94da2c8c4c1d7bfc2cc7b56d486dfc64beb8facfff7ef551412034b8
Contents?: true
Size: 854 Bytes
Versions: 1
Compression:
Stored size: 854 Bytes
Contents
require "bigdecimal" module MathUtil def self.mean(arr) arr.inject(:+) / arr.length.to_f end def self.population_variance(population) mean = mean(population) sum = population.map { |element| ((element - mean) ** 2) }.inject(:+) (sum/population.length) end def self.volatility(population) population.compact! if population.is_a?(Array) && population.any? variance = MathUtil.population_variance(population) (((variance * 252) ** 0.5) * 100).round(4) end end def self.sharpe(fund, bmark, volatility) sharpe = 100 * ( ((1 + mean(fund)) ** 252 - 1) - ((1 + mean(bmark)) ** 252 - 1)) / volatility puts sharpe sharpe.round(4) if sharpe > 0 end def self.annual_tax_day_equivalent(annual_tax) BigDecimal.new((1 + annual_tax) ** (1/252.0) - 1, 16) if annual_tax end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
math_util-0.1.0 | lib/math_util.rb |