123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225 |
- <?php
- namespace MathPHP\Tests\LinearAlgebra\Matrix\Other;
- use MathPHP\LinearAlgebra\Householder;
- use MathPHP\LinearAlgebra\MatrixFactory;
- class HouseholderTest extends \PHPUnit\Framework\TestCase
- {
- use \MathPHP\Tests\LinearAlgebra\Fixture\MatrixDataProvider;
- /**
- * @test Householder transformation creates a matrix that is involutory
- * @dataProvider dataProviderForHouseholder
- * @param array $A
- * @throws \Exception
- */
- public function testHouseholderTransformMatrixInvolutoryProperty(array $A)
- {
- // Given
- $A = MatrixFactory::create($A);
- // When
- $H = Householder::transform($A);
- // Then
- $this->assertTrue($H->isInvolutory());
- }
- /**
- * @test Householder transformation creates a matrix with a determinant that is -1
- * @dataProvider dataProviderForHouseholder
- * @param array $A
- * @throws \Exception
- */
- public function testHouseholderTransformMatrixDeterminant(array $A)
- {
- // Given
- $A = MatrixFactory::create($A);
- // When
- $H = Householder::transform($A);
- // Then
- $this->assertEqualsWithDelta(-1, $H->det(), 0.000001);
- }
- /**
- * @test Householder transformation creates a matrix that has eigenvalues 1 and -1
- * @dataProvider dataProviderForHouseholder
- * @param array $A
- * @throws \Exception
- */
- public function testHouseholderTransformMatrixEigenvalues(array $A)
- {
- // Given
- $A = MatrixFactory::create($A);
- // When
- $H = Householder::transform($A);
- // Then
- $eigenvalues = \array_filter(
- $H->eigenvalues(),
- function ($x) {
- return !\is_nan($x);
- }
- );
- $this->assertEqualsWithDelta(1, max($eigenvalues), 0.00001);
- $this->assertEqualsWithDelta(-1, \min($eigenvalues), 0.00001);
- }
- /**
- * @return array
- */
- public function dataProviderForHouseholder(): array
- {
- return [
- [
- [
- [4, 1, -2, 2],
- [1, 2, 0, 1],
- [-2, 0, 3, -2],
- [2, 1, -2, -1],
- ]
- ],
- [
- [
- [1, 0, 0, 0],
- [0, -1 / 3, 2 / 3, -2 / 3],
- [0, 2 / 3, 2 / 3, 1 / 3],
- [0, -2 / 3, 1 / 3, 2 / 3],
- ]
- ],
- [
- [
- [1, 0, 0, 0],
- [0, 1, 0, 0],
- [0, 0, -3 / 5, -4 / 5],
- [0, 0, -4 / 5, 3 / 5],
- ]
- ],
- [
- [
- [2, -2, 18],
- [2, 1, 0],
- [1, 2, 0],
- ],
- ],
- [
- [
- [-1.8, 12],
- [2.4, -6],
- ],
- ],
- [
- [
- [1, 0, 0, 0, 0],
- [0, 0, 1, 0, 0],
- [1, -7, 0, 4, 2],
- [0, 4, 2, -7, 1],
- [0, 2, 0, 1, -7],
- ],
- ],
- [
- [
- [0, 1, 0, 0],
- [4.9497, 0, -2.8284, -1.4142],
- [4, 2, -7, 1],
- [2, 0, 1, -7],
- ],
- ],
- [
- [
- [-1.6318, 1.6208, 0.4767],
- [0.6813, -3.4045, 2.5281],
- [-0.6594, 2.7978, -6.236],
- ],
- ],
- [
- [
- [1.8953, -5.8889],
- [-2.3316, 1.9103],
- ],
- ],
- [
- [
- [6, 3],
- [8, 4],
- ]
- ],
- [
- [
- [2, -2, 18],
- [2, 1, 0],
- [1, 2, 0],
- ]
- ],
- [
- [
- [12, -51, 4],
- [ 6, 167, -68],
- [-4, 24, -41],
- ]
- ],
- [
- [
- [4, 3, 7],
- [1, 3, 6],
- [8, 5, 7],
- ]
- ],
- [
- [
- [1, 2, 3, 2],
- [4, 5, 6, 2],
- [7, 8, 9, 2],
- [4, 5, 5, 6],
- ]
- ],
- [
- [
- [7, 8, 9, 2],
- [1, 2, 3, 2],
- [4, -3, 2, 12],
- [4, 1, -6, 6],
- ]
- ],
- [
- [
- [3, 7, 6, 4, 5],
- [2, 3, 6, 5, 8],
- [2, 3, 4, 1, 0],
- [3, 7, 6, 7, 7],
- [1, 3, 4, 9, 4],
- ]
- ],
- [
- [
- [2, -2, -3],
- [0, -6, -1],
- [0, 0, 1],
- [0, 0, 4],
- ]
- ],
- [
- [
- [1,0,0],
- [0,0,0],
- [0,0,0],
- [0,0,0],
- ]
- ],
- [
- [
- [3, 7, 6, 4, 5, 8],
- [2, 3, 6, 5, 8, 9],
- [2, 3, 4, 1, 0, 9],
- [3, 7, 6, 7, 7, 3],
- [1, 3, 4, 9, 4, 8],
- ]
- ],
- ];
- }
- }
|