sixarm_ruby_math_statistics 1.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.
Binary file
File without changes
@@ -0,0 +1,88 @@
1
+ # SixArm.com » Ruby » <br> Math Statistics
2
+
3
+ * Docs: <http://sixarm.com/sixarm_ruby_math_statistics/doc>
4
+ * Repo: <http://github.com/sixarm/sixarm_ruby_math_statistics>
5
+ * Email: Joel Parker Henderson, <joel@sixarm.com>
6
+
7
+
8
+ ## Introduction
9
+
10
+ Math statistics methods.
11
+
12
+ See http://pallas.telperion.info/ruby-stats/
13
+
14
+ For docs go to <http://sixarm.com/sixarm_ruby_math_statistics/doc>
15
+
16
+ Want to help? We're happy to get pull requests.
17
+
18
+
19
+ ## Quickstart
20
+
21
+ Install:
22
+
23
+ gem install sixarm_ruby_math_statistics
24
+
25
+ Bundler:
26
+
27
+ gem "sixarm_ruby_math_statistics", "=1.2.0"
28
+
29
+ Require:
30
+
31
+ require "sixarm_ruby_math_statistics"
32
+
33
+
34
+ ## High Security (Optional)
35
+
36
+ To enable high security for all our gems:
37
+
38
+ wget http://sixarm.com/sixarm.pem
39
+ gem cert --add sixarm.pem
40
+ gem sources --add http://sixarm.com
41
+
42
+ To install with high security:
43
+
44
+ gem install sixarm_ruby_ --test --trust-policy HighSecurity
45
+
46
+
47
+ ## Examples
48
+
49
+ require "sixarm_ruby_math_statistics"
50
+ [1,2].sum => 3
51
+ [1,2].mean => 1.5
52
+ [1,2].mean => 1.5
53
+ [1,2].variance => 0.25
54
+ [1,2].deviation => 0.5
55
+
56
+
57
+ ## Changes
58
+
59
+ * 2012-03-14 1.1.0 Update docs, tests
60
+
61
+
62
+ ## License
63
+
64
+ You may choose any of these open source licenses:
65
+
66
+ * Apache License
67
+ * BSD License
68
+ * CreativeCommons License, Non-commercial Share Alike
69
+ * GNU General Public License Version 2 (GPL 2)
70
+ * GNU Lesser General Public License (LGPL)
71
+ * MIT License
72
+ * Perl Artistic License
73
+ * Ruby License
74
+
75
+ The software is provided "as is", without warranty of any kind,
76
+ express or implied, including but not limited to the warranties of
77
+ merchantability, fitness for a particular purpose and noninfringement.
78
+
79
+ In no event shall the authors or copyright holders be liable for any
80
+ claim, damages or other liability, whether in an action of contract,
81
+ tort or otherwise, arising from, out of or in connection with the
82
+ software or the use or other dealings in the software.
83
+
84
+ This license is for the included software that is created by SixArm;
85
+ some of the included software may have its own licenses, copyrights,
86
+ authors, etc. and these do take precedence over the SixArm license.
87
+
88
+ Copyright (c) 2005-2013 Joel Parker Henderson
@@ -0,0 +1,8 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'rake'
3
+ require 'rake/testtask'
4
+
5
+ Rake::TestTask.new(:test) do |t|
6
+ t.libs << 'lib' << 'test'
7
+ t.pattern = 'test/*.rb'
8
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 1.1.8
@@ -0,0 +1,88 @@
1
+ # -*- coding: utf-8 -*-
2
+ =begin rdoc
3
+ Please see README
4
+ =end
5
+
6
+
7
+ module Enumerable
8
+
9
+
10
+ # Examples
11
+ # [].sum => 0
12
+ # [1].sum => 1
13
+ # [1,2,3].sum => 5
14
+ #
15
+ # Example with default for empty
16
+ # [].sum(99) => 99
17
+ #
18
+ # Example with block
19
+ # [1,2,3].sum{|x| x*2} => 10
20
+ #
21
+ # This method is copied from rails to ensure compatibility.
22
+
23
+ def sum(identity = 0, &block)
24
+ return identity unless size > 0
25
+ if block_given?
26
+ map(&block).sum
27
+ else
28
+ inject { |sum, element| sum + element }
29
+ end
30
+ end
31
+
32
+
33
+ # Examples
34
+ # [].mean => nil
35
+ # [1].mean => 1.0
36
+ # [1,2].mean => 1.5
37
+ # [1,2,9].mean => 4.0
38
+
39
+ def mean
40
+ size==0 ? nil : sum.to_f / size
41
+ end
42
+
43
+
44
+ # Examples
45
+ # [].median => nil
46
+ # [1].median => 1.0
47
+ # [1,2].median => 1.5
48
+ # [1,2,9].mean => 2.0
49
+
50
+ def median
51
+ size==0 ? nil : ((0==self.size%2) ? sort[size/2-1,2].mean : sort[self.size/2].to_f)
52
+ end
53
+
54
+
55
+ # Examples
56
+ # [].sum_of_squares => 0
57
+ # [1].sum_of_squares => 1.0
58
+ # [1,2].sum_of_squares => 5.0
59
+ # [1,2,3].sum_of_squares => 14.0
60
+
61
+ def sum_of_squares
62
+ size==0 ? 0 : inject(0){|sum,x|sum+(x*x)}
63
+ end
64
+
65
+
66
+ # Examples
67
+ # [].variance => nil
68
+ # [1].variance => 0.0
69
+ # [1,2].variance => 0.25
70
+ # [1,2,3,4].variance => 1.25
71
+
72
+ def variance
73
+ size==0 ? nil : ( m=mean and sum_of_squares.to_f/size - m*m )
74
+ end
75
+
76
+
77
+ # Examples
78
+ # [].deviation => nil
79
+ # [1].deviation => 0.0
80
+ # [1,2].deviation => 0.5
81
+ # [2,2,4,2,2].deviation => 0.8
82
+
83
+ def deviation
84
+ size==0 ? nil : Math::sqrt(variance)
85
+ end
86
+
87
+ end
88
+
@@ -0,0 +1,129 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'minitest/autorun'
3
+ require 'simplecov'
4
+ SimpleCov.start
5
+ require 'sixarm_ruby_math_statistics'
6
+
7
+ describe Enumerable do
8
+
9
+ describe "#sum" do
10
+
11
+ it "[] => 0, which tests edge case" do
12
+ [].sum.must_equal 0
13
+ end
14
+
15
+ it "[1] => 1, which tests minimal case" do
16
+ [1].sum.must_equal 1
17
+ end
18
+
19
+ it "[1, 2] => 3, which tests a couple args" do
20
+ [1, 2].sum.must_equal 3
21
+ end
22
+
23
+ it "[1, 2, 3] => 6, which tests a few args" do
24
+ [1,2,3].sum.must_equal 6
25
+ end
26
+
27
+ end
28
+
29
+ describe "#mean" do
30
+
31
+ it "[] => nil, which tests edge case" do
32
+ [].mean.must_equal nil
33
+ end
34
+
35
+ it "[1] => 1.0, which tests minimal case" do
36
+ [1].mean.must_equal 1.0
37
+ end
38
+
39
+ it "[1, 2] => 1.5, which tests a couple args" do
40
+ [1,2].mean.must_equal 1.5
41
+ end
42
+
43
+ it "[1, 2, 9] => 4.0, which tests a few args and distinguishes mean and median" do
44
+ [1,2,9].mean.must_equal 4.0
45
+ end
46
+
47
+ end
48
+
49
+ describe "#median" do
50
+
51
+ it "[] => nil, which tests edge case" do
52
+ [].median.must_equal nil
53
+ end
54
+
55
+ it "[1] => 1.0, which tests minimal case" do
56
+ [1].median.must_equal 1.0
57
+ end
58
+
59
+ it "[1, 2] => 1.5, which tests a couple args" do
60
+ [1,2].median.must_equal 1.5
61
+ end
62
+
63
+ it "[1, 2, 9] => 2.0, which tests a few args and distiguishes mean from median" do
64
+ [1,2,9].median.must_equal 2.0
65
+ end
66
+
67
+ end
68
+
69
+ describe "#sum_of_squares" do
70
+
71
+ it "[] => 0, which tests edge case" do
72
+ [].sum_of_squares.must_equal []
73
+ end
74
+
75
+ it "[1] => 1.0, which tests minimal case" do
76
+ [1].sum_of_squares.must_equal 1.0
77
+ end
78
+
79
+ it "[1, 2] => 5.0, which tests a couple args" do
80
+ [1,2].sum_of_squares.must_equal 5.0
81
+ end
82
+
83
+ it "[1,2,3] => 14.0, which tests few args" do
84
+ [1,2,3].sum_of_squares.must_equal 14.0
85
+ end
86
+
87
+ end
88
+
89
+ describe "#variance" do
90
+
91
+ it "[] => 0, which tests edge case" do
92
+ [].variance.must_equal nil
93
+ end
94
+
95
+ it "[1] => 0, which tests minimal case" do
96
+ [1].variance.must_equal 0.0
97
+ end
98
+
99
+ it "[1, 2] => 0.25, which tests a couple args" do
100
+ [1,2].variance.must_equal 0.25
101
+ end
102
+
103
+ it "[1,2,3,4] => 1.25, which tests a few args" do
104
+ [1,2,3,4].variance.must_equal 1.25
105
+ end
106
+
107
+ end
108
+
109
+ describe "#deviation" do
110
+
111
+ it "[] => 0, which tests edge case" do
112
+ [].deviation.must_equal 0
113
+ end
114
+
115
+ it "[1] => 0, which tests minimal case" do
116
+ [1].deviation.must_equal 0.0
117
+ end
118
+
119
+ it "[1, 2] => 0.25, which tests a couple args" do
120
+ [1,2].deviation.must_equal 0.5
121
+ end
122
+
123
+ it "[2, 2, 4, 2, 2] => 0.8 with delta 0.001, which tests a small delta" do
124
+ [2,2,4,2,2].deviation.must_equal 0.8 # TODO delta 0.001
125
+ end
126
+
127
+ end
128
+
129
+ end
metadata ADDED
@@ -0,0 +1,79 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sixarm_ruby_math_statistics
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.2.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - SixArm
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain:
12
+ - !binary |-
13
+ LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSURCRENDQW0yZ0F3SUJB
14
+ Z0lKQUtQd0VFVFU1YkhvTUEwR0NTcUdTSWIzRFFFQkJRVUFNR0F4Q3pBSkJn
15
+ TlYKQkFZVEFsVlRNUk13RVFZRFZRUUlFd3BEWVd4cFptOXlibWxoTVJZd0ZB
16
+ WURWUVFIRXcxVFlXNGdSbkpoYm1OcApjMk52TVE4d0RRWURWUVFLRXdaVGFY
17
+ aEJjbTB4RXpBUkJnTlZCQU1UQ25OcGVHRnliUzVqYjIwd0hoY05NVEF4Ck1q
18
+ RXpNak15TnpFeldoY05NVE13T1RBNE1qTXlOekV6V2pCZ01Rc3dDUVlEVlFR
19
+ R0V3SlZVekVUTUJFR0ExVUUKQ0JNS1EyRnNhV1p2Y201cFlURVdNQlFHQTFV
20
+ RUJ4TU5VMkZ1SUVaeVlXNWphWE5qYnpFUE1BMEdBMVVFQ2hNRwpVMmw0UVhK
21
+ dE1STXdFUVlEVlFRREV3cHphWGhoY20wdVkyOXRNSUdmTUEwR0NTcUdTSWIz
22
+ RFFFQkFRVUFBNEdOCkFEQ0JpUUtCZ1FDOTRtRDlKRHdCc3Vuc09JMFZSM0NY
23
+ WGJPV2c5Y1dhV2Npd0Z5Sk5GaU03QTlJOEtQTGZYVXcKUUM0Y3pVZTVadUc0
24
+ V0h2aW5yV2hrckNLKzFkV0Jxb0VDbHhkRi9Gb0tPNWErdG9uR0Nqam1meTgx
25
+ Sm1Gamp5eAplVHNqc0h5dncrUWlrOWtwZjlhajYrcG5rTnJWc3dnTkhWZWEy
26
+ bzl5YWJiRWlTNlZTZUpXb1FJREFRQUJvNEhGCk1JSENNQjBHQTFVZERnUVdC
27
+ QlF6UEp0cW1TZ2M1M2VETjdhU3pEUXdyOVRBTERDQmtnWURWUjBqQklHS01J
28
+ R0gKZ0JRelBKdHFtU2djNTNlRE43YVN6RFF3cjlUQUxLRmtwR0l3WURFTE1B
29
+ a0dBMVVFQmhNQ1ZWTXhFekFSQmdOVgpCQWdUQ2tOaGJHbG1iM0p1YVdFeEZq
30
+ QVVCZ05WQkFjVERWTmhiaUJHY21GdVkybHpZMjh4RHpBTkJnTlZCQW9UCkJs
31
+ TnBlRUZ5YlRFVE1CRUdBMVVFQXhNS2MybDRZWEp0TG1OdmJZSUpBS1B3RUVU
32
+ VTViSG9NQXdHQTFVZEV3UUYKTUFNQkFmOHdEUVlKS29aSWh2Y05BUUVGQlFB
33
+ RGdZRUFvb0VleFAvb1BhbTFUUDcxU3l1aHhNYit1VHJaYlNRZQpqVkIrRXhS
34
+ d1dhZEd3YU5QVUE1NmQzOXF3YXZ3UCtpdSszSnBlb25OTVZ2YldYRjVuYUNY
35
+ L2RORkllUkVIekVSClpEUlFZTXFydTlURU1uYTZIRDl6cGNzdEY3dndUaEdv
36
+ dmxPUSszWTZwbFE0bk16aXBYY1o5VEhxczY1UElMMHEKZWFid3BDYkFvcG89
37
+ Ci0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0K
38
+ date: 2012-03-17 00:00:00.000000000 Z
39
+ dependencies: []
40
+ description:
41
+ email: sixarm@sixarm.com
42
+ executables: []
43
+ extensions: []
44
+ extra_rdoc_files: []
45
+ files:
46
+ - .gemtest
47
+ - Rakefile
48
+ - README.md
49
+ - VERSION
50
+ - lib/sixarm_ruby_math_statistics.rb
51
+ - test/sixarm_ruby_math_statistics_test.rb
52
+ homepage: http://sixarm.com/
53
+ licenses: []
54
+ post_install_message:
55
+ rdoc_options: []
56
+ require_paths:
57
+ - lib
58
+ required_ruby_version: !ruby/object:Gem::Requirement
59
+ none: false
60
+ requirements:
61
+ - - ! '>='
62
+ - !ruby/object:Gem::Version
63
+ version: '0'
64
+ required_rubygems_version: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ! '>='
68
+ - !ruby/object:Gem::Version
69
+ version: '0'
70
+ requirements: []
71
+ rubyforge_project:
72
+ rubygems_version: 1.8.11
73
+ signing_key:
74
+ specification_version: 3
75
+ summary: ! 'SixArm Ruby Gem: Math statitics methods for sum, mean, median, mode, variance,
76
+ deviation, etc.'
77
+ test_files:
78
+ - test/sixarm_ruby_math_statistics_test.rb
79
+ has_rdoc: true
Binary file