252 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			252 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | ||
|  | declare(strict_types = 1); | ||
|  | 
 | ||
|  | namespace BaconQrCodeTest\Encoder; | ||
|  | 
 | ||
|  | use BaconQrCode\Encoder\ByteMatrix; | ||
|  | use BaconQrCode\Encoder\MaskUtil; | ||
|  | use PHPUnit\Framework\TestCase; | ||
|  | 
 | ||
|  | class MaskUtilTest extends TestCase | ||
|  | { | ||
|  |     public function dataMaskBits() : array | ||
|  |     { | ||
|  |         return [ | ||
|  |             [0, [ | ||
|  |                 [1, 0, 1, 0, 1, 0], | ||
|  |                 [0, 1, 0, 1, 0, 1], | ||
|  |                 [1, 0, 1, 0, 1, 0], | ||
|  |                 [0, 1, 0, 1, 0, 1], | ||
|  |                 [1, 0, 1, 0, 1, 0], | ||
|  |                 [0, 1, 0, 1, 0, 1], | ||
|  |             ]], | ||
|  |             [1, [ | ||
|  |                 [1, 1, 1, 1, 1, 1], | ||
|  |                 [0, 0, 0, 0, 0, 0], | ||
|  |                 [1, 1, 1, 1, 1, 1], | ||
|  |                 [0, 0, 0, 0, 0, 0], | ||
|  |                 [1, 1, 1, 1, 1, 1], | ||
|  |                 [0, 0, 0, 0, 0, 0], | ||
|  |             ]], | ||
|  |             [2, [ | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |             ]], | ||
|  |             [3, [ | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [0, 0, 1, 0, 0, 1], | ||
|  |                 [0, 1, 0, 0, 1, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [0, 0, 1, 0, 0, 1], | ||
|  |                 [0, 1, 0, 0, 1, 0], | ||
|  |             ]], | ||
|  |             [4, [ | ||
|  |                 [1, 1, 1, 0, 0, 0], | ||
|  |                 [1, 1, 1, 0, 0, 0], | ||
|  |                 [0, 0, 0, 1, 1, 1], | ||
|  |                 [0, 0, 0, 1, 1, 1], | ||
|  |                 [1, 1, 1, 0, 0, 0], | ||
|  |                 [1, 1, 1, 0, 0, 0], | ||
|  |             ]], | ||
|  |             [5, [ | ||
|  |                 [1, 1, 1, 1, 1, 1], | ||
|  |                 [1, 0, 0, 0, 0, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 1, 0, 1, 0], | ||
|  |                 [1, 0, 0, 1, 0, 0], | ||
|  |                 [1, 0, 0, 0, 0, 0], | ||
|  |             ]], | ||
|  |             [6, [ | ||
|  |                 [1, 1, 1, 1, 1, 1], | ||
|  |                 [1, 1, 1, 0, 0, 0], | ||
|  |                 [1, 1, 0, 1, 1, 0], | ||
|  |                 [1, 0, 1, 0, 1, 0], | ||
|  |                 [1, 0, 1, 1, 0, 1], | ||
|  |                 [1, 0, 0, 0, 1, 1], | ||
|  |             ]], | ||
|  |             [7, [ | ||
|  |                 [1, 0, 1, 0, 1, 0], | ||
|  |                 [0, 0, 0, 1, 1, 1], | ||
|  |                 [1, 0, 0, 0, 1, 1], | ||
|  |                 [0, 1, 0, 1, 0, 1], | ||
|  |                 [1, 1, 1, 0, 0, 0], | ||
|  |                 [0, 1, 1, 1, 0, 0], | ||
|  |             ]], | ||
|  |         ]; | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @dataProvider dataMaskBits | ||
|  |      */ | ||
|  |     public function testGetDatMaskBit(int $maskPattern, array $expected) : void | ||
|  |     { | ||
|  |         for ($x = 0; $x < 6; ++$x) { | ||
|  |             for ($y = 0; $y < 6; ++$y) { | ||
|  |                 $this->assertSame( | ||
|  |                     1 === $expected[$y][$x], | ||
|  |                     MaskUtil::getDataMaskBit($maskPattern, $x, $y) | ||
|  |                 ); | ||
|  |             } | ||
|  |         } | ||
|  |     } | ||
|  | 
 | ||
|  |     public function testApplyMaskPenaltyRule1() : void | ||
|  |     { | ||
|  |         $matrix = new ByteMatrix(4, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(2, 0, 0); | ||
|  |         $matrix->set(3, 0, 0); | ||
|  | 
 | ||
|  |         $this->assertSame(0, MaskUtil::applyMaskPenaltyRule1($matrix)); | ||
|  | 
 | ||
|  |         // Horizontal
 | ||
|  |         $matrix = new ByteMatrix(6, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(2, 0, 0); | ||
|  |         $matrix->set(3, 0, 0); | ||
|  |         $matrix->set(4, 0, 0); | ||
|  |         $matrix->set(5, 0, 1); | ||
|  |         $this->assertSame(3, MaskUtil::applyMaskPenaltyRule1($matrix)); | ||
|  |         $matrix->set(5, 0, 0); | ||
|  |         $this->assertSame(4, MaskUtil::applyMaskPenaltyRule1($matrix)); | ||
|  | 
 | ||
|  |         // Vertical
 | ||
|  |         $matrix = new ByteMatrix(1, 6); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(0, 1, 0); | ||
|  |         $matrix->set(0, 2, 0); | ||
|  |         $matrix->set(0, 3, 0); | ||
|  |         $matrix->set(0, 4, 0); | ||
|  |         $matrix->set(0, 5, 1); | ||
|  |         $this->assertSame(3, MaskUtil::applyMaskPenaltyRule1($matrix)); | ||
|  |         $matrix->set(0, 5, 0); | ||
|  |         $this->assertSame(4, MaskUtil::applyMaskPenaltyRule1($matrix)); | ||
|  |     } | ||
|  | 
 | ||
|  |     public function testApplyMaskPenaltyRule2() : void | ||
|  |     { | ||
|  |         $matrix = new ByteMatrix(1, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $this->assertSame(0, MaskUtil::applyMaskPenaltyRule2($matrix)); | ||
|  | 
 | ||
|  |         $matrix = new ByteMatrix(2, 2); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(0, 1, 0); | ||
|  |         $matrix->set(1, 1, 1); | ||
|  |         $this->assertSame(0, MaskUtil::applyMaskPenaltyRule2($matrix)); | ||
|  | 
 | ||
|  |         $matrix = new ByteMatrix(2, 2); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(0, 1, 0); | ||
|  |         $matrix->set(1, 1, 0); | ||
|  |         $this->assertSame(3, MaskUtil::applyMaskPenaltyRule2($matrix)); | ||
|  | 
 | ||
|  |         $matrix = new ByteMatrix(3, 3); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(2, 0, 0); | ||
|  |         $matrix->set(0, 1, 0); | ||
|  |         $matrix->set(1, 1, 0); | ||
|  |         $matrix->set(2, 1, 0); | ||
|  |         $matrix->set(0, 2, 0); | ||
|  |         $matrix->set(1, 2, 0); | ||
|  |         $matrix->set(2, 2, 0); | ||
|  |         $this->assertSame(3 * 4, MaskUtil::applyMaskPenaltyRule2($matrix)); | ||
|  |     } | ||
|  | 
 | ||
|  |     public function testApplyMaskPenalty3() : void | ||
|  |     { | ||
|  |         // Horizontal 00001011101
 | ||
|  |         $matrix = new ByteMatrix(11, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(2, 0, 0); | ||
|  |         $matrix->set(3, 0, 0); | ||
|  |         $matrix->set(4, 0, 1); | ||
|  |         $matrix->set(5, 0, 0); | ||
|  |         $matrix->set(6, 0, 1); | ||
|  |         $matrix->set(7, 0, 1); | ||
|  |         $matrix->set(8, 0, 1); | ||
|  |         $matrix->set(9, 0, 0); | ||
|  |         $matrix->set(10, 0, 1); | ||
|  |         $this->assertSame(40, MaskUtil::applyMaskPenaltyRule3($matrix)); | ||
|  | 
 | ||
|  |         // Horizontal 10111010000
 | ||
|  |         $matrix = new ByteMatrix(11, 1); | ||
|  |         $matrix->set(0, 0, 1); | ||
|  |         $matrix->set(1, 0, 0); | ||
|  |         $matrix->set(2, 0, 1); | ||
|  |         $matrix->set(3, 0, 1); | ||
|  |         $matrix->set(4, 0, 1); | ||
|  |         $matrix->set(5, 0, 0); | ||
|  |         $matrix->set(6, 0, 1); | ||
|  |         $matrix->set(7, 0, 0); | ||
|  |         $matrix->set(8, 0, 0); | ||
|  |         $matrix->set(9, 0, 0); | ||
|  |         $matrix->set(10, 0, 0); | ||
|  |         $this->assertSame(40, MaskUtil::applyMaskPenaltyRule3($matrix)); | ||
|  | 
 | ||
|  |         // Vertical 00001011101
 | ||
|  |         $matrix = new ByteMatrix(1, 11); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(0, 1, 0); | ||
|  |         $matrix->set(0, 2, 0); | ||
|  |         $matrix->set(0, 3, 0); | ||
|  |         $matrix->set(0, 4, 1); | ||
|  |         $matrix->set(0, 5, 0); | ||
|  |         $matrix->set(0, 6, 1); | ||
|  |         $matrix->set(0, 7, 1); | ||
|  |         $matrix->set(0, 8, 1); | ||
|  |         $matrix->set(0, 9, 0); | ||
|  |         $matrix->set(0, 10, 1); | ||
|  |         $this->assertSame(40, MaskUtil::applyMaskPenaltyRule3($matrix)); | ||
|  | 
 | ||
|  |         // Vertical 10111010000
 | ||
|  |         $matrix = new ByteMatrix(1, 11); | ||
|  |         $matrix->set(0, 0, 1); | ||
|  |         $matrix->set(0, 1, 0); | ||
|  |         $matrix->set(0, 2, 1); | ||
|  |         $matrix->set(0, 3, 1); | ||
|  |         $matrix->set(0, 4, 1); | ||
|  |         $matrix->set(0, 5, 0); | ||
|  |         $matrix->set(0, 6, 1); | ||
|  |         $matrix->set(0, 7, 0); | ||
|  |         $matrix->set(0, 8, 0); | ||
|  |         $matrix->set(0, 9, 0); | ||
|  |         $matrix->set(0, 10, 0); | ||
|  |         $this->assertSame(40, MaskUtil::applyMaskPenaltyRule3($matrix)); | ||
|  |     } | ||
|  | 
 | ||
|  |     public function testApplyMaskPenaltyRule4() : void | ||
|  |     { | ||
|  |         // Dark cell ratio = 0%
 | ||
|  |         $matrix = new ByteMatrix(1, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $this->assertSame(100, MaskUtil::applyMaskPenaltyRule4($matrix)); | ||
|  | 
 | ||
|  |         // Dark cell ratio = 5%
 | ||
|  |         $matrix = new ByteMatrix(2, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(0, 0, 1); | ||
|  |         $this->assertSame(0, MaskUtil::applyMaskPenaltyRule4($matrix)); | ||
|  | 
 | ||
|  |         // Dark cell ratio = 66.67%
 | ||
|  |         $matrix = new ByteMatrix(6, 1); | ||
|  |         $matrix->set(0, 0, 0); | ||
|  |         $matrix->set(1, 0, 1); | ||
|  |         $matrix->set(2, 0, 1); | ||
|  |         $matrix->set(3, 0, 1); | ||
|  |         $matrix->set(4, 0, 1); | ||
|  |         $matrix->set(5, 0, 0); | ||
|  |         $this->assertSame(30, MaskUtil::applyMaskPenaltyRule4($matrix)); | ||
|  |     } | ||
|  | } |