From 1e696acc7e86a6d57fe6afa91c7478420c62bc2b Mon Sep 17 00:00:00 2001 From: marcandre Date: Sat, 9 Jul 2011 02:41:14 +0000 Subject: [PATCH] * lib/matrix.rb: Add Vector#normalize [ruby-dev:43829] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32467 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 4 ++++ NEWS | 3 ++- lib/matrix.rb | 27 +++++++++++++++++++++++++++ 3 files changed, 33 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index b6e32cbe61..fd338aed71 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Sat Jul 9 11:41:03 2011 Marc-Andre Lafortune + + * lib/matrix.rb: Add Vector#normalize [ruby-dev:43829] + Sat Jul 9 09:25:06 2011 Eric Hodel * enumerator.c: Remove "enumeration sequenced by". diff --git a/NEWS b/NEWS index 5f691b8a4a..1bd986f8cc 100644 --- a/NEWS +++ b/NEWS @@ -182,7 +182,8 @@ with all sufficient information, see the ChangeLog file. * Matrix#unitary? * Matrix#upper_triangular? * Matrix#zero? - * Vector#magnitude + * Vector#magnitude, #norm + * Vector#normalize * extended methods: * Matrix#each and #each_with_index can iterate on a subset of the elements * Matrix#find_index returns [row, column] and can iterate on a subset diff --git a/lib/matrix.rb b/lib/matrix.rb index b4ff31a218..360e79f3cc 100644 --- a/lib/matrix.rb +++ b/lib/matrix.rb @@ -1517,8 +1517,11 @@ end # Vector functions: # * #inner_product(v) # * #collect +# * #magnitude # * #map # * #map2(v) +# * #norm +# * #normalize # * #r # * #size # @@ -1778,6 +1781,30 @@ class Vector Math.sqrt(@elements.inject(0) {|v, e| v + e*e}) end alias r magnitude + alias norm magnitude + + # + # Like Vector#collect2, but returns a Vector instead of an Array. + # + def map2(v, &block) # :yield: e1, e2 + return to_enum(:map2, v) unless block_given? + els = collect2(v, &block) + Vector.elements(els, false) + end + + class ZeroVectorError < StandardError + end + # + # Returns a new vector with the same direction but with norm 1. + # v = Vector[5,8,2].normalize + # # => Vector[0.5184758473652127, 0.8295613557843402, 0.20739033894608505] + # v.norm => 1.0 + # + def normalize + n = magnitude + raise ZeroVectorError, "Zero vectors can not be normalized" if n == 0 + self / n + end #-- # CONVERTING