summaryrefslogtreecommitdiff
path: root/spec/ruby/library/matrix/rank_spec.rb
blob: d4403d23ed0c42b2d2174b35cb926df5c0268c4d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
require_relative '../../spec_helper'
require 'matrix'

describe "Matrix#rank" do
  it "returns the rank of the Matrix" do
    Matrix[ [7,6], [3,9] ].rank.should == 2
  end

  it "doesn't loop forever" do
    Matrix[ [1,2,3], [4,5,6], [7,8,9] ].rank.should == 2
    Matrix[ [1, 2, 0, 3], [1, -2, 3, 0], [0, 0, 4, 8], [2, 4, 0, 6] ].rank.
    should == 3
  end

  it "works for some easy rectangular matrices" do
    Matrix[[0,0],[0,0],[1,0]].rank.should == 1
    Matrix[[0,1],[0,0],[1,0]].rank.should == 2
  end
end