descriptive_statistics 1.1.1 → 1.1.2

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.
@@ -0,0 +1,17 @@
1
+ module DescriptiveStatistics
2
+ def descriptive_statistics
3
+ return { :number => self.size.to_f,
4
+ :sum => self.sum,
5
+ :variance => self.variance,
6
+ :standard_deviation => self.standard_deviation,
7
+ :min => self.min,
8
+ :max => self.max,
9
+ :mean => self.mean,
10
+ :mode => self.mode,
11
+ :median => self.median,
12
+ :range => self.range,
13
+ :q1 => self.percentile(25),
14
+ :q2 => self.percentile(50),
15
+ :q3 => self.percentile(75) }
16
+ end
17
+ end
@@ -0,0 +1,6 @@
1
+ module DescriptiveStatistics
2
+ def range
3
+ return 0 unless self.number > 0
4
+ self.max - self.min
5
+ end
6
+ end
@@ -6,3 +6,6 @@ require 'descriptive_statistics/mode.rb'
6
6
  require 'descriptive_statistics/variance.rb'
7
7
  require 'descriptive_statistics/standard_deviation.rb'
8
8
  require 'descriptive_statistics/percentile.rb'
9
+ require 'descriptive_statistics/range.rb'
10
+ require 'descriptive_statistics/descriptive_statistics.rb'
11
+
data/test/test.rb CHANGED
@@ -56,5 +56,38 @@ class TestData < MiniTest::Unit::TestCase
56
56
  assert_equal test_case[0,10].percentile(100).round(6), test_case[25].round(6)
57
57
  end
58
58
  end
59
-
60
- end
59
+
60
+ def test_mode
61
+ assert_equal [1,3,6,9,4,5,2,3,4,1,6,7,8,3,2,3,5,7,8,5,6,5,6,5,4,5,5,5].mode, 5
62
+ end
63
+
64
+ def test_range
65
+ assert_equal [17, 5, 3, 23, 33, 30, 45, 37].range, 42
66
+ assert_equal [].range, 0
67
+ assert_equal [1, 1.0].range, 0
68
+ end
69
+
70
+ def test_descriptive_statistics
71
+ @data.each do |test_case|
72
+ stat = test_case[0, 10].descriptive_statistics
73
+ assert_equal test_case[0, 10].sum, stat[:sum]
74
+ assert_equal test_case[0, 10].mean, stat[:mean]
75
+ assert_equal test_case[0, 10].median, stat[:median]
76
+ assert_equal test_case[0, 10].variance, stat[:variance]
77
+ assert_equal test_case[0, 10].standard_deviation, stat[:standard_deviation]
78
+ assert_equal test_case[0, 10].mode, stat[:mode]
79
+ assert_equal test_case[0, 10].range, stat[:range]
80
+ assert_equal test_case[0, 10].min, stat[:min]
81
+ assert_equal test_case[0, 10].max, stat[:max]
82
+ assert_equal test_case[0, 10].percentile(25), stat[:q1]
83
+ assert_equal test_case[0, 10].percentile(50), stat[:q2]
84
+ assert_equal test_case[0, 10].percentile(75), stat[:q3]
85
+ end
86
+ end
87
+
88
+ def test_median_is_percentile50
89
+ @data.each do |test_case|
90
+ assert_equal test_case[0, 10].median, test_case[0, 10].percentile(50)
91
+ end
92
+ end
93
+ end
metadata CHANGED
@@ -1,17 +1,18 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: descriptive_statistics
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.1
4
+ version: 1.1.2
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
8
8
  - Derrick Parkhurst
9
9
  - Gregory Brown
10
10
  - Daniel Farrell
11
+ - Graham Malmgren
11
12
  autorequire:
12
13
  bindir: bin
13
14
  cert_chain: []
14
- date: 2012-12-01 00:00:00.000000000 Z
15
+ date: 2013-07-11 00:00:00.000000000 Z
15
16
  dependencies: []
16
17
  description: Adds descriptive statistics methods to Enumerable for use on collections
17
18
  email: derrick.parkhurst@gmail.com
@@ -19,12 +20,14 @@ executables: []
19
20
  extensions: []
20
21
  extra_rdoc_files: []
21
22
  files:
23
+ - lib/descriptive_statistics/descriptive_statistics.rb
22
24
  - lib/descriptive_statistics/enumerable_extension.rb
23
25
  - lib/descriptive_statistics/mean.rb
24
26
  - lib/descriptive_statistics/median.rb
25
27
  - lib/descriptive_statistics/mode.rb
26
28
  - lib/descriptive_statistics/number.rb
27
29
  - lib/descriptive_statistics/percentile.rb
30
+ - lib/descriptive_statistics/range.rb
28
31
  - lib/descriptive_statistics/safe.rb
29
32
  - lib/descriptive_statistics/standard_deviation.rb
30
33
  - lib/descriptive_statistics/sum.rb