expectException(InvalidArgumentException::class); $actualLabels = ['a', 'b', 'a', 'b']; $predictedLabels = ['a', 'a']; Accuracy::score($actualLabels, $predictedLabels); } public function testCalculateNormalizedScore(): void { $actualLabels = ['a', 'b', 'a', 'b']; $predictedLabels = ['a', 'a', 'b', 'b']; self::assertEquals(0.5, Accuracy::score($actualLabels, $predictedLabels)); } public function testCalculateNotNormalizedScore(): void { $actualLabels = ['a', 'b', 'a', 'b']; $predictedLabels = ['a', 'b', 'b', 'b']; self::assertEquals(3, Accuracy::score($actualLabels, $predictedLabels, false)); } public function testAccuracyOnDemoDataset(): void { $dataset = new RandomSplit(new IrisDataset(), 0.5, 123); $classifier = new SVC(Kernel::RBF); $classifier->train($dataset->getTrainSamples(), $dataset->getTrainLabels()); $predicted = (array) $classifier->predict($dataset->getTestSamples()); $accuracy = Accuracy::score($dataset->getTestLabels(), $predicted); $expected = PHP_VERSION_ID >= 70100 ? 1 : 0.959; self::assertEqualsWithDelta($expected, $accuracy, 0.01); } }