123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- <?php
- /**
- * BaconQrCode
- *
- * @link http://github.com/Bacon/BaconQrCode For the canonical source repository
- * @copyright 2013 Ben 'DASPRiD' Scholzen
- * @license http://opensource.org/licenses/BSD-2-Clause Simplified BSD License
- */
- namespace BaconQrCode\Common;
- use PHPUnit_Framework_TestCase as TestCase;
- use SplFixedArray;
- class ReedSolomonTest extends TestCase
- {
- public static function tabProvider()
- {
- return array(
- array(2, 0x7, 1, 1, 1),
- array(3, 0xb, 1, 1, 2),
- array(4, 0x13, 1, 1, 4),
- array(5, 0x25, 1, 1, 6),
- array(6, 0x43, 1, 1, 8),
- array(7, 0x89, 1, 1, 10),
- array(8, 0x11d, 1, 1, 32),
- );
- }
- /**
- * @dataProvider tabProvider
- * @param integer $symbolSize
- * @param integer $generatorPoly
- * @param integer $firstRoot
- * @param integer $primitive
- * @param integer $numRoots
- * @return void
- */
- public function testCodec($symbolSize, $generatorPoly, $firstRoot, $primitive, $numRoots)
- {
- if (defined('MT_RAND_PHP')) {
- mt_srand(0xdeadbeef, MT_RAND_PHP);
- } else {
- mt_srand(0xdeadbeef);
- }
- $blockSize = (1 << $symbolSize) - 1;
- $dataSize = $blockSize - $numRoots;
- $codec = new ReedSolomonCodec($symbolSize, $generatorPoly, $firstRoot, $primitive, $numRoots, 0);
- for ($errors = 0; $errors <= $numRoots / 2; $errors++) {
- // Load block with random data and encode
- $block = SplFixedArray::fromArray(array_fill(0, $blockSize, 0), false);
- for ($i = 0; $i < $dataSize; $i++) {
- $block[$i] = mt_rand(0, $blockSize);
- }
- // Make temporary copy
- $tBlock = clone $block;
- $parity = SplFixedArray::fromArray(array_fill(0, $numRoots, 0), false);
- $errorLocations = SplFixedArray::fromArray(array_fill(0, $blockSize, 0), false);
- $erasures = array();
- // Create parity
- $codec->encode($block, $parity);
- // Copy parity into test blocks
- for ($i = 0; $i < $numRoots; $i++) {
- $block[$i + $dataSize] = $parity[$i];
- $tBlock[$i + $dataSize] = $parity[$i];
- }
- // Seed with errors
- for ($i = 0; $i < $errors; $i++) {
- $errorValue = mt_rand(1, $blockSize);
- do {
- $errorLocation = mt_rand(0, $blockSize);
- } while ($errorLocations[$errorLocation] !== 0);
- $errorLocations[$errorLocation] = 1;
- if (mt_rand(0, 1)) {
- $erasures[] = $errorLocation;
- }
- $tBlock[$errorLocation] ^= $errorValue;
- }
- $erasures = SplFixedArray::fromArray($erasures, false);
- // Decode the errored block
- $foundErrors = $codec->decode($tBlock, $erasures);
- if ($errors > 0 && $foundErrors === null) {
- $this->assertEquals($block, $tBlock, 'Decoder failed to correct errors');
- }
- $this->assertEquals($errors, $foundErrors, 'Found errors do not equal expected errors');
- for ($i = 0; $i < $foundErrors; $i++) {
- if ($errorLocations[$erasures[$i]] === 0) {
- $this->fail(sprintf('Decoder indicates error in location %d without error', $erasures[$i]));
- }
- }
- $this->assertEquals($block, $tBlock, 'Decoder did not correct errors');
- }
- }
- }
|