Class: Vector

Inherits:
Object show all
Defined in:
lib/classifier/extensions/vector.rb

Constant Summary collapse

EPSILON =
1e-10

Instance Method Summary collapse

Instance Method Details

#magnitudeObject



24
25
26
27
28
29
30
# File 'lib/classifier/extensions/vector.rb', line 24

def magnitude
  sum_of_squares = 0.to_r
  size.times do |i|
    sum_of_squares += self[i]**2.to_r
  end
  Math.sqrt(sum_of_squares.to_f)
end

#normalizeObject



32
33
34
35
36
37
38
39
40
41
# File 'lib/classifier/extensions/vector.rb', line 32

def normalize
  magnitude_value = magnitude
  return Vector[*Array.new(size, 0.0)] if magnitude_value <= 0.0

  normalized_values = []
  size.times do |i|
    normalized_values << (self[i] / magnitude_value)
  end
  Vector[*normalized_values]
end