Class: Matrix
- Inherits:
-
Object
- Object
- Matrix
- Defined in:
- lib/avsd.rb
Instance Method Summary collapse
- #[]=(i, j, x) ⇒ Object
- #flatten ⇒ Object
- #flip ⇒ Object
- #fold ⇒ Object
- #mirror_diagonal ⇒ Object
- #show ⇒ Object
- #zero_diagonal ⇒ Object
Instance Method Details
#[]=(i, j, x) ⇒ Object
8 9 10 |
# File 'lib/avsd.rb', line 8 def []=(i, j, x) @rows[i][j] = x end |
#flatten ⇒ Object
64 65 66 67 68 69 70 71 72 |
# File 'lib/avsd.rb', line 64 def flatten arr = [] for col in 0..self.column_size - 1 for row in 0..self.row_size - 1 arr << self[col, row] end end arr end |
#flip ⇒ Object
52 53 54 55 56 57 58 59 60 61 62 |
# File 'lib/avsd.rb', line 52 def flip m = self.flatten.max + 1 for col in 0..self.column_size - 1 for row in 0..self.row_size - 1 next if self[col, row] == 0 self[col, row] -= m self[col, row] *= -1 end end self end |
#fold ⇒ Object
12 13 14 15 16 17 18 19 20 21 |
# File 'lib/avsd.rb', line 12 def fold for col in 0..self.column_size - 1 for row in col..self.row_size - 1 sum = self[row, col] + self[col, row] self[row, col] = sum self[col, row] = sum end end self end |
#mirror_diagonal ⇒ Object
35 36 37 38 39 40 41 42 43 |
# File 'lib/avsd.rb', line 35 def mirror_diagonal self.fold for col in 0..self.column_size - 1 for row in 0..self.row_size - 1 self[col, row] /= 2.0 end end self end |
#show ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/avsd.rb', line 23 def show puts [self.column_size, self.row_size].inspect for col in 0..self.column_size - 1 for row in 0..self.row_size - 1 print self[row, col] == nil ? "n" : self[row, col] print " " end puts end self end |
#zero_diagonal ⇒ Object
45 46 47 48 49 50 |
# File 'lib/avsd.rb', line 45 def zero_diagonal for col in 0..self.column_size - 1 self[col, col] = 0 end self end |