2018-02-24 19:17:35 +09:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace Phpml\Tests\Dataset;
|
|
|
|
|
|
|
|
use Phpml\Dataset\SvmDataset;
|
|
|
|
use Phpml\Exception\DatasetException;
|
|
|
|
use Phpml\Exception\FileException;
|
|
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
|
|
|
|
class SvmDatasetTest extends TestCase
|
|
|
|
{
|
|
|
|
public function testSvmDatasetEmpty(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('empty.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDataset1x1(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('1x1.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
[2.3],
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
0,
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDataset3x1(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('3x1.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
[2.3],
|
|
|
|
[4.56],
|
|
|
|
[78.9],
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
1,
|
|
|
|
0,
|
|
|
|
1,
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDataset3x4(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('3x4.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
[2, 4, 6, 8],
|
|
|
|
[3, 5, 7, 9],
|
|
|
|
[1.2, 3.4, 5.6, 7.8],
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
1,
|
|
|
|
2,
|
|
|
|
0,
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetSparse(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('sparse.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
[0, 3.45, 0, 0, 0],
|
|
|
|
[0, 0, 0, 0, 6.789],
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
0,
|
|
|
|
1,
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetComments(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('comments.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
[2],
|
|
|
|
[34],
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
0,
|
|
|
|
1,
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetTabs(): void
|
|
|
|
{
|
|
|
|
$filePath = self::getFilePath('tabs.svm');
|
|
|
|
$dataset = new SvmDataset($filePath);
|
|
|
|
|
|
|
|
$expectedSamples = [
|
|
|
|
[23, 45],
|
|
|
|
];
|
|
|
|
$expectedTargets = [
|
|
|
|
1,
|
|
|
|
];
|
|
|
|
|
|
|
|
$this->assertEquals($expectedSamples, $dataset->getSamples());
|
|
|
|
$this->assertEquals($expectedTargets, $dataset->getTargets());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetMissingFile(): void
|
|
|
|
{
|
|
|
|
$this->expectException(FileException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('File "err_file_not_exists.svm" missing.');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_file_not_exists.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetEmptyLine(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid target "".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_empty_line.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetNoLabels(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid target "1:2.3".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_no_labels.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetStringLabels(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid target "A".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_string_labels.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetInvalidSpaces(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid target "".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_invalid_spaces.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetStringIndex(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid index "x".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_string_index.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetIndexZero(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid index "0".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_index_zero.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetInvalidValue(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid value "xyz".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_invalid_value.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testSvmDatasetInvalidFeature(): void
|
|
|
|
{
|
|
|
|
$this->expectException(DatasetException::class);
|
2018-10-16 21:42:06 +02:00
|
|
|
$this->expectExceptionMessage('Invalid value "12345".');
|
2018-02-24 19:17:35 +09:00
|
|
|
|
2018-10-16 21:42:06 +02:00
|
|
|
new SvmDataset(self::getFilePath('err_invalid_feature.svm'));
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
private static function getFilePath(string $baseName): string
|
|
|
|
{
|
2018-10-16 21:42:06 +02:00
|
|
|
return __DIR__.'/Resources/svm/'.$baseName;
|
2018-02-24 19:17:35 +09:00
|
|
|
}
|
|
|
|
}
|