From 9d4ea92a5a861d6f84a1561c370e6721bba4b7e4 Mon Sep 17 00:00:00 2001 From: Glen Whitney Date: Tue, 1 Mar 2022 05:42:35 -0800 Subject: [PATCH] fix(eigs): Handle matrices with complex entries (#2445) This change fixes a typing problem in complexEigs.js in which real-valued norms were inadvertently being typed as complex numbers. Resolves #2439 Co-authored-by: Jos de Jong --- src/function/matrix/eigs/complexEigs.js | 11 ++++++----- test/unit-tests/function/matrix/eigs.test.js | 9 +++++++++ 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/src/function/matrix/eigs/complexEigs.js b/src/function/matrix/eigs/complexEigs.js index f942cbb62f..1d5c66c573 100644 --- a/src/function/matrix/eigs/complexEigs.js +++ b/src/function/matrix/eigs/complexEigs.js @@ -64,8 +64,9 @@ export function createComplexEigs ({ addScalar, subtract, flatten, multiply, mul const big = type === 'BigNumber' const cplx = type === 'Complex' - const zero = big ? bignumber(0) : cplx ? complex(0) : 0 + const realzero = big ? bignumber(0) : 0 const one = big ? bignumber(1) : cplx ? complex(1) : 1 + const realone = big ? bignumber(1) : 1 // base of the floating-point arithmetic const radix = big ? bignumber(10) : 2 @@ -87,12 +88,12 @@ export function createComplexEigs ({ addScalar, subtract, flatten, multiply, mul for (let i = 0; i < N; i++) { // compute the taxicab norm of i-th column and row // TODO optimize for complex numbers - let colNorm = zero - let rowNorm = zero + let colNorm = realzero + let rowNorm = realzero for (let j = 0; j < N; j++) { if (i === j) continue - const c = abs(arr[i][j]) + const c = abs(arr[i][j]) // should be real colNorm = addScalar(colNorm, c) rowNorm = addScalar(rowNorm, c) } @@ -102,7 +103,7 @@ export function createComplexEigs ({ addScalar, subtract, flatten, multiply, mul // (we want to scale only by integer powers of radix, // so that we don't lose any precision due to round-off) - let f = one + let f = realone let c = colNorm const rowDivRadix = divideScalar(rowNorm, radix) diff --git a/test/unit-tests/function/matrix/eigs.test.js b/test/unit-tests/function/matrix/eigs.test.js index 047659218e..2f808184fa 100644 --- a/test/unit-tests/function/matrix/eigs.test.js +++ b/test/unit-tests/function/matrix/eigs.test.js @@ -65,6 +65,15 @@ describe('eigs', function () { ) }) + it('calculates eigenvalues for 2x2 matrix with complex entries', () => { + approx.deepEqual( + eigs([[3, -2], [complex(4, 2), -1]]).values, + [complex(0.08982028, 2.197368227), complex(1.91017972, -2.197368227)]) + approx.deepEqual( + eigs([[2, -2], [complex(0, 2), complex(0, -2)]]).values, + [0, complex(2, -2)]) + }) + it('calculates eigenvalues for 3x3 and 4x4 matrix', function () { // 3x3 test and 4x4 approx.deepEqual(eigs(