Module: KMeansClusterer::Scaler
- Defined in:
- lib/kmeans-clusterer.rb
Class Method Summary collapse
- .mean(data) ⇒ Object
- .row_norms(data) ⇒ Object
- .scale(data, mean = nil, std = nil, typecode = nil) ⇒ Object
- .std(data) ⇒ Object
Class Method Details
.mean(data) ⇒ Object
23 24 25 |
# File 'lib/kmeans-clusterer.rb', line 23 def self.mean data data.mean(1) end |
.row_norms(data) ⇒ Object
41 42 43 44 |
# File 'lib/kmeans-clusterer.rb', line 41 def self.row_norms data squared_data = NArray.ref(data)**2 NMatrix.ref(squared_data).sum(0) end |
.scale(data, mean = nil, std = nil, typecode = nil) ⇒ Object
33 34 35 36 37 38 39 |
# File 'lib/kmeans-clusterer.rb', line 33 def self.scale data, mean = nil, std = nil, typecode = nil data = NArray.ref(data) mean ||= self.mean(data) std ||= self.std(data) data = (data - mean) / std [NMatrix.ref(data), mean, std] end |
.std(data) ⇒ Object
27 28 29 30 31 |
# File 'lib/kmeans-clusterer.rb', line 27 def self.std data std = data.stddev(1) std[std.eq(0)] = 1.0 # so we don't divide by 0 std end |