Class: Matrix
- Inherits:
-
Object
- Object
- Matrix
- Defined in:
- lib/matrix_extensions.rb
Overview
An extension to the Ruby Matrix class.
Class Method Summary collapse
-
.hconcat(*matrices) ⇒ Matrix
Concatenates two matrices horizontally (resulting in more columns).
-
.ones(rows = 1, columns = 1) ⇒ Matrix
Matrix prefilled with ones.
-
.vconcat(*matrices) ⇒ Matrix
Concatenates two matrices vertically (resulting in more rows).
-
.zeros(rows = 1, columns = 1) ⇒ Matrix
Matrix prefilled with zeros.
Instance Method Summary collapse
-
#element_division(m) ⇒ Matrix
Element-wise division.
-
#element_exponentiation(m) ⇒ Matrix
Element-wise exponentiation.
-
#element_multiplication(m) ⇒ Matrix
Element-wise multiplication.
Class Method Details
.hconcat(*matrices) ⇒ Matrix
Concatenates two matrices horizontally (resulting in more columns).
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/matrix_extensions.rb', line 27 def self.hconcat(*matrices) columns = [] matrices.each do |m| raise TypeError, "#{m.class} is not a Matrix or Vector" unless m.is_a?(Matrix) || m.is_a?(Vector) # convert Vector to Matrix m = self.convert_vector_to_matrix(m, :column) if m.is_a? Vector # check if dimensions match row_count ||= m.row_count Matrix.Raise ErrDimensionMismatch unless row_count == m.row_count # prepare array of columns m.column_vectors.each do |v| columns << v.to_a end end # create new matrix self.columns(columns) end |
.ones(rows = 1, columns = 1) ⇒ Matrix
Matrix prefilled with ones.
18 19 20 |
# File 'lib/matrix_extensions.rb', line 18 def self.ones(rows = 1, columns = 1) Matrix.build(rows, columns) { 1 } end |
.vconcat(*matrices) ⇒ Matrix
Concatenates two matrices vertically (resulting in more rows).
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/matrix_extensions.rb', line 54 def self.vconcat(*matrices) rows = [] matrices.each do |m| raise TypeError, "#{m.class} is not a Matrix or Vector" unless m.is_a?(Matrix) || m.is_a?(Vector) # convert Vector to Matrix m = self.convert_vector_to_matrix(m, :row) if m.is_a? Vector # check if dimensions match column_count ||= m.column_count Matrix.Raise ErrDimensionMismatch unless column_count == m.column_count # prepare array of columns m.row_vectors.each do |v| rows << v.to_a end end # create new matrix self.rows(rows) end |
Instance Method Details
#element_division(m) ⇒ Matrix
Element-wise division.
80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 |
# File 'lib/matrix_extensions.rb', line 80 def element_division(m) case m when Numeric return self./ m when Vector if row_count > column_count # Matrix is of dimension X * 1 (or there'll be an ErrDimensionMismatch) m = self.class.convert_vector_to_matrix(m, :column) else # Matrix is of dimension 1 * X (or there'll be an ErrDimensionMismatch) m = self.class.convert_vector_to_matrix(m, :row) end when Matrix else return apply_through_coercion(m, __method__) end Matrix.Raise ErrDimensionMismatch unless row_count == m.row_count && column_count == m.column_count rows = Array.new(row_count) do |i| Array.new(column_count) do|j| self[i, j] / m[i, j] end end new_matrix rows, column_count end |
#element_exponentiation(m) ⇒ Matrix
Element-wise exponentiation.
142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 |
# File 'lib/matrix_extensions.rb', line 142 def element_exponentiation(m) case m when Numeric # self.** m will break rows = @rows.collect {|row| row.collect {|e| e ** m } } return new_matrix rows, column_count when Vector if row_count > column_count # Matrix is of dimension X * 1 (or there'll be an ErrDimensionMismatch) m = self.class.convert_vector_to_matrix(m, :column) else # Matrix is of dimension 1 * X (or there'll be an ErrDimensionMismatch) m = self.class.convert_vector_to_matrix(m, :row) end when Matrix else return apply_through_coercion(m, __method__) end Matrix.Raise ErrDimensionMismatch unless row_count == m.row_count && column_count == m.column_count rows = Array.new(row_count) do |i| Array.new(column_count) do|j| self[i, j] ** m[i, j] end end new_matrix rows, column_count end |
#element_multiplication(m) ⇒ Matrix
Element-wise multiplication.
111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 |
# File 'lib/matrix_extensions.rb', line 111 def element_multiplication(m) case m when Numeric return self.* m when Vector if row_count > column_count # Matrix is of dimension X * 1 (or there'll be an ErrDimensionMismatch) m = self.class.convert_vector_to_matrix(m, :column) else # Matrix is of dimension 1 * X (or there'll be an ErrDimensionMismatch) m = self.class.convert_vector_to_matrix(m, :row) end when Matrix else return apply_through_coercion(m, __method__) end Matrix.Raise ErrDimensionMismatch unless row_count == m.row_count && column_count == m.column_count rows = Array.new(row_count) do |i| Array.new(column_count) do|j| self[i, j] * m[i, j] end end new_matrix rows, column_count end |