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

describe "Matrix::EigenvalueDecomposition#eigenvector_matrix" do
  it "returns a complex eigenvector matrix given a rotation matrix" do
    # Fix me: should test for linearity, not for equality
    Matrix[[ 1, 1],
           [-1, 1]].eigensystem.eigenvector_matrix.should ==
    Matrix[[1, 1],
           [Complex(0, 1), Complex(0, -1)]]
  end

  it "returns an real eigenvector matrix for a symetric matrix" do
    # Fix me: should test for linearity, not for equality
    Matrix[[1, 2],
           [2, 1]].eigensystem.eigenvector_matrix.should ==
    Matrix[[0.7071067811865475, 0.7071067811865475],
           [-0.7071067811865475, 0.7071067811865475]]
  end
end