cluster($samples); $this->assertCount(2, $clusters); foreach ($samples as $index => $sample) { if (in_array($sample, $clusters[0], true) || in_array($sample, $clusters[1], true)) { unset($samples[$index]); } } $this->assertCount(0, $samples); return $fcm; } public function testMembershipMatrix(): void { $fcm = $this->testFCMSamplesClustering(); $clusterCount = 2; $sampleCount = 6; $matrix = $fcm->getMembershipMatrix(); $this->assertCount($clusterCount, $matrix); foreach ($matrix as $row) { $this->assertCount($sampleCount, $row); } // Transpose of the matrix array_unshift($matrix, null); $matrix = call_user_func_array('array_map', $matrix); // All column totals should be equal to 1 (100% membership) foreach ($matrix as $col) { $this->assertEquals(1, array_sum($col)); } } /** * @dataProvider invalidClusterNumberProvider */ public function testInvalidClusterNumber(int $clusters): void { $this->expectException(InvalidArgumentException::class); new FuzzyCMeans($clusters); } public function invalidClusterNumberProvider(): array { return [[0], [-1]]; } }