azami 0.0.2

Sign up to get free protection for your applications and to get access to all the features.
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: []