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

ruby_version_is ""..."3.1" do
  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 symmetric 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
end