summaryrefslogtreecommitdiff
path: root/lib/classification.rb
diff options
context:
space:
mode:
authorChristoph Helma <helma@in-silico.ch>2016-10-12 21:32:27 +0200
committerChristoph Helma <helma@in-silico.ch>2016-10-12 21:32:27 +0200
commitdc4ab1f4e64d738d6c0b70f0b690a2359685080f (patch)
tree054ae887bf978b519a95dce5dbead59bbc67a2bb /lib/classification.rb
parent1ec5ad2c67f270287499980a794e51bc9a6bbd84 (diff)
physchem regression, correlation_filter for fingerprints
Diffstat (limited to 'lib/classification.rb')
-rw-r--r--lib/classification.rb23
1 files changed, 8 insertions, 15 deletions
diff --git a/lib/classification.rb b/lib/classification.rb
index 6582e7d..e8c179f 100644
--- a/lib/classification.rb
+++ b/lib/classification.rb
@@ -3,24 +3,17 @@ module OpenTox
class Classification
- def self.weighted_majority_vote descriptors:nil, neighbors:, method:nil, relevant_features:nil
- sims = {}
- neighbors.each do |neighbor|
- sim = neighbor["similarity"]
- activities = neighbor["measurements"]
- activities.each do |act|
- sims[act] ||= []
- sims[act] << sim
- end if activities
+ def self.weighted_majority_vote dependent_variables:, independent_variables:nil, weights:, query_variables:
+ class_weights = {}
+ dependent_variables.each_with_index do |v,i|
+ class_weights[v] ||= []
+ class_weights[v] << weights[i] unless v.nil?
end
- sim_all = sims.collect{|a,s| s}.flatten
- sim_sum = sim_all.sum
- sim_max = sim_all.max
probabilities = {}
- sims.each do |a,s|
- probabilities[a] = s.sum/sim_sum
+ class_weights.each do |a,w|
+ probabilities[a] = w.sum/weights.sum
end
- probabilities = probabilities.collect{|a,p| [a,sim_max*p]}.to_h
+ probabilities = probabilities.collect{|a,p| [a,weights.max*p]}.to_h
p_max = probabilities.collect{|a,p| p}.max
prediction = probabilities.key(p_max)
{:value => prediction,:probabilities => probabilities}