aboutsummaryrefslogtreecommitdiffstats
path: root/spec/rubyspec/library/matrix/rank_spec.rb
blob: 42b6de1ab83657d508ad098d2f132208707b46f6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
require File.expand_path('../../../spec_helper', __FILE__)
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