Sha256: d941d7a423ac71025401dc9ca7ed1b4da989c8035915d779371c5509e4b71509

Contents?: true

Size: 906 Bytes

Versions: 5

Compression:

Stored size: 906 Bytes

Contents

# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Numo::Linalg do
  describe 'eigvals' do
    let(:m) { 5 }
    let(:mat_a) { Numo::DFloat.new(m, m).rand - 0.5 }
    let(:mat_b) { mat_a + Complex::I * (Numo::DFloat.new(m, m).rand - 0.5) }

    it 'raises ShapeError given a rectangular matrix' do
      expect { described_class.eigh(Numo::DFloat.new(2, 4).rand) }.to raise_error(Numo::NArray::ShapeError)
    end

    it 'finds eigenvalues for a square nonsymmetric matrix' do
      w1 = described_class.eigvals(mat_a)
      w2, = described_class.eig(mat_a, left: false, right: false)
      expect((w1 - w2).abs.max).to be < ERR_TOL
    end

    it 'finds eigenvalues for a square complex nonsymmetric matrix' do
      w1 = described_class.eigvals(mat_b)
      w2, = described_class.eig(mat_b, left: false, right: false)
      expect((w1 - w2).abs.max).to be < ERR_TOL
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
numo-linalg-0.1.7 spec/linalg/function/eigvals_spec.rb
numo-linalg-0.1.6 spec/linalg/function/eigvals_spec.rb
numo-linalg-0.1.5 spec/linalg/function/eigvals_spec.rb
numo-linalg-0.1.4 spec/linalg/function/eigvals_spec.rb
numo-linalg-0.1.3 spec/linalg/function/eigvals_spec.rb