floatstats 0.1.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (5) hide show
  1. data/Rakefile +1 -1
  2. data/VERSION +1 -1
  3. data/floatstats.gemspec +1 -1
  4. data/lib/floatstats.rb +26 -0
  5. metadata +10 -10
data/Rakefile CHANGED
@@ -15,7 +15,7 @@ require 'jeweler'
15
15
  Jeweler::Tasks.new do |gem|
16
16
  # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
17
17
  gem.name = "floatstats"
18
- gem.version = "0.1.1"
18
+ gem.version = "0.2.0"
19
19
  gem.homepage = "http://github.com/fizquierdo/floatstats"
20
20
  gem.license = "MIT"
21
21
  gem.summary = %Q{stats for arrays of fp numbers}
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.1.1
1
+ 0.2.0
data/floatstats.gemspec CHANGED
@@ -5,7 +5,7 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = %q{floatstats}
8
- s.version = "0.1.1"
8
+ s.version = "0.2.0"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = [%q{Fernando Izquierdo-Carrasco}]
data/lib/floatstats.rb CHANGED
@@ -28,4 +28,30 @@ module Enumerable
28
28
  def standard_deviation
29
29
  Math.sqrt(self.sample_variance)
30
30
  end
31
+ # operations with 2 enumerable vectors
32
+ def self.product(x,y)
33
+ x.zip(y).map{|i,j| i*j}
34
+ end
35
+ def self.distance(x,y)
36
+ x.zip(y).map{|i,j| i-j}
37
+ end
38
+ def self.ratio(x,y)
39
+ x.zip(y).map{|i,j| i.to_f / j.to_f}
40
+ end
41
+ def self.pearson_correlation(x, y)
42
+ xda = x.diffavg
43
+ yda = y.diffavg
44
+ num = self.product(xda, yda).sum
45
+ den = Math.sqrt(xda.sum_of_squares * yda.sum_of_squares)
46
+ num / den
47
+ end
48
+ def self.spearman_rank(x, y)
49
+ n = x.size
50
+ num = 6 * self.distance(x.rank, y.rank).sum_of_squares
51
+ den = n * (n**2 - 1)
52
+ 1.0 - num.to_f/den.to_f
53
+ end
54
+ def self.spearman_rank2(x, y)
55
+ self.pearson_correlation(x.rank, y.rank)
56
+ end
31
57
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: floatstats
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.2.0
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2011-09-19 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: shoulda
16
- requirement: &6083100 !ruby/object:Gem::Requirement
16
+ requirement: &17552720 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :development
23
23
  prerelease: false
24
- version_requirements: *6083100
24
+ version_requirements: *17552720
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: bundler
27
- requirement: &5942260 !ruby/object:Gem::Requirement
27
+ requirement: &17493020 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: 1.0.0
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *5942260
35
+ version_requirements: *17493020
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: jeweler
38
- requirement: &5941400 !ruby/object:Gem::Requirement
38
+ requirement: &17492160 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 1.6.4
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *5941400
46
+ version_requirements: *17492160
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: rcov
49
- requirement: &5940480 !ruby/object:Gem::Requirement
49
+ requirement: &17490820 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,7 +54,7 @@ dependencies:
54
54
  version: '0'
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *5940480
57
+ version_requirements: *17490820
58
58
  description: ! 'stats for fp arrays: stddev, average, etc'
59
59
  email: fer.izquierdo@gmail.com
60
60
  executables: []
@@ -91,7 +91,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
91
91
  version: '0'
92
92
  segments:
93
93
  - 0
94
- hash: 2653380643967933362
94
+ hash: -466524050253698854
95
95
  required_rubygems_version: !ruby/object:Gem::Requirement
96
96
  none: false
97
97
  requirements: