Skip to content

Commit

Permalink
Separate array and object extensions from id3_tree
Browse files Browse the repository at this point in the history
  • Loading branch information
Danielius committed Nov 20, 2015
1 parent 6adbebb commit 9ee1fdd
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 11 deletions.
25 changes: 25 additions & 0 deletions lib/core_extensions/array.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
class Array
def classification
collect(&:last)
end

# calculate information entropy
def entropy
return 0 if empty?

info = {}
total = 0
each do |i|
info[i] = !info[i] ? 1 : (info[i] + 1)
total += 1
end

result = 0
info.each do |_symbol, count|
if count > 0
result += -count.to_f / total * Math.log(count.to_f / total) / Math.log(2.0)
end
end
result
end
end
9 changes: 9 additions & 0 deletions lib/core_extensions/object.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
class Object
def save_to_file(filename)
File.open(filename, 'w+') { |f| f << Marshal.dump(self) }
end

def self.load_from_file(filename)
Marshal.load(File.read(filename))
end
end
3 changes: 2 additions & 1 deletion lib/decisiontree.rb
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
require File.dirname(__FILE__) + '/decisiontree/id3_tree.rb'
require 'core_extension/array.rb'
require 'core_extensions/object'
require 'core_extensions/array'
10 changes: 0 additions & 10 deletions lib/decisiontree/id3_tree.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,6 @@
### Copyright (c) 2007 Ilya Grigorik <ilya AT igvita DOT com>
### Modifed at 2007 by José Ignacio Fernández <joseignacio.fernandez AT gmail DOT com>

class Object
def save_to_file(filename)
File.open(filename, 'w+') { |f| f << Marshal.dump(self) }
end

def self.load_from_file(filename)
Marshal.load(File.read(filename))
end
end

module DecisionTree
Node = Struct.new(:attribute, :threshold, :gain)

Expand Down

0 comments on commit 9ee1fdd

Please sign in to comment.