azami 0.0.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.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/azami.rb +32 -0
  3. metadata +72 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 7ab05804a9638e3b584242d1ceade1e1595a7cb9
4
+ data.tar.gz: 3f67fcfb9d870e8b4c6b6a765f7c1c6843bb6842
5
+ SHA512:
6
+ metadata.gz: b7fca74c5f0ead536db8bfd462037e204f20ad4d8c3f6d418b07d266e33b26e77925e97938a232a527f9193548e3e391196d75b4e629f47b8d9139341088adfe
7
+ data.tar.gz: 45d81c1dfa3fdc229dd001f730199981a04946f5a8d76f0396aa7b7fc333d6ce60b824d0063c36a1cb5815ea6e2e0a2aaf80d4ad96496d096941451136c74bc9
data/lib/azami.rb ADDED
@@ -0,0 +1,32 @@
1
+ module Azami
2
+
3
+ def self.em(data)
4
+
5
+ inputs, normal_params, iteration_count =
6
+ data[:inputs], data[:normal_params], data[:iteration_count]
7
+
8
+ iteration_count.times{
9
+ likelihood_weights =
10
+ inputs.map { |input|
11
+ likelihoods = normal_params.map { |normal_param|
12
+ mean,stdev = normal_param[:mean],normal_param[:stdev]
13
+ (0.398942*(2.71828**(-(0.5*(input - mean)**2)/stdev**2)))/stdev
14
+ }
15
+ total_likelihood = likelihoods.sum
16
+ likelihoods.map { |lk|
17
+ lk/total_likelihood
18
+ }
19
+ }.transpose
20
+
21
+ normal_params.each_with_index { |normal_param, normal_index|
22
+ weights = likelihood_weights[normal_index]
23
+ weights_sum = weights.sum
24
+ normal_param[:mean] = mean = (weights.map.with_index { |weight,input_i|
25
+ (weight*inputs[input_i])}.sum)/(weights_sum)
26
+ normal_param[:stdev] = Math.sqrt(((weights.map.with_index { |weight,input_i|
27
+ (((inputs[input_i]-mean)**2)*weight) }).sum)/(weights_sum))
28
+ }
29
+ }
30
+ normal_params
31
+ end
32
+ end
metadata ADDED
@@ -0,0 +1,72 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: azami
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.2
5
+ platform: ruby
6
+ authors:
7
+ - forvelin
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2018-12-13 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rake
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '10.0'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '10.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: minitest
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '5.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '5.0'
41
+ description: An EM gem
42
+ email:
43
+ executables: []
44
+ extensions: []
45
+ extra_rdoc_files: []
46
+ files:
47
+ - lib/azami.rb
48
+ homepage: http://rubygems.org/gems/azami
49
+ licenses:
50
+ - MIT
51
+ metadata: {}
52
+ post_install_message:
53
+ rdoc_options: []
54
+ require_paths:
55
+ - lib
56
+ required_ruby_version: !ruby/object:Gem::Requirement
57
+ requirements:
58
+ - - ">="
59
+ - !ruby/object:Gem::Version
60
+ version: '0'
61
+ required_rubygems_version: !ruby/object:Gem::Requirement
62
+ requirements:
63
+ - - ">="
64
+ - !ruby/object:Gem::Version
65
+ version: '0'
66
+ requirements: []
67
+ rubyforge_project:
68
+ rubygems_version: 2.6.14.1
69
+ signing_key:
70
+ specification_version: 4
71
+ summary: Azami
72
+ test_files: []