2010-02-18 21:14:35 +00:00
using System ;
using Microsoft.VisualStudio.TestTools.UnitTesting ;
using CUETools.Codecs ;
2010-04-23 19:59:42 +00:00
using CUETools.CDImage ;
using CUETools.AccurateRip ;
2011-04-08 14:41:28 +00:00
using CUETools.TestHelpers ;
2011-04-24 21:07:50 +00:00
using CUETools.Parity ;
2010-02-18 21:14:35 +00:00
namespace CUETools.TestParity
{
/// <summary>
///This is a test class for CDRepairDecodeTest and is intended
///to contain all CDRepairDecodeTest Unit Tests
///</summary>
[TestClass()]
public class CDRepairDecodeTest
{
2011-04-08 14:41:28 +00:00
// CD has maximum of 360.000 sectors;
// If stride equals 10 sectors (10 sectors * 588 samples * 2 words),
// then maximum sequence length is 36.000 sectors.
// 36.000 is less than (65535 - npar), so we're ok here.
// npar == 8 provides error correction for 4 samples out of every 36k,
// i.e. at best one sample per 9k can be repaired.
// Parity data per one CD requires 10 * 588 * 4 * npar bytes,
// which equals 188.160b == 184kb
// We might consider shorter strides to reduce parity data size,
// but it probably should still be a multiple of 588 * 2;
// (or the size of CD CIRC buffer?)
2010-02-18 21:14:35 +00:00
const int stride = 10 * 588 * 2 ;
2011-04-08 14:41:28 +00:00
const int errors = stride / 4 ;
2010-02-18 21:14:35 +00:00
const int offset = 48 ;
2011-04-08 14:41:28 +00:00
const int seed = 2423 ;
2010-02-18 21:14:35 +00:00
//const int offset = 5 * 588 - 5;
//const int offset = 2000;
2011-04-08 14:41:28 +00:00
private static TestImageGenerator generator ;
private static CDRepairEncode encode ;
2011-11-15 10:56:49 +00:00
private static string encodeSyndrome ;
private static string encodeSyndromePosOffset ;
private static string encodeSyndromeNegOffset ;
private static string encodeSyndrome1 ;
2011-10-27 20:50:11 +00:00
private static string [ ] encodeParity = new string [ 33 ] ;
private TestContext testContextInstance ;
2010-02-18 21:14:35 +00:00
/// <summary>
///Gets or sets the test context which provides
///information about and functionality for the current test run.
///</summary>
public TestContext TestContext
{
get
{
return testContextInstance ;
}
set
{
testContextInstance = value ;
}
}
#region Additional test attributes
//
//You can use the following additional attributes as you write your tests:
//
//Use ClassInitialize to run code before running the first test in the class
[ClassInitialize()]
public static void MyClassInitialize ( TestContext testContext )
{
2011-04-08 14:41:28 +00:00
generator = new TestImageGenerator ( "0 9801" , seed , 32 * 588 , 0 ) ;
2011-10-27 20:50:11 +00:00
encode = generator . CreateCDRepairEncode ( stride ) ;
2011-11-15 10:56:49 +00:00
encodeSyndrome = "DP5e7sS+kHjtAEb/o599As2tA3puoW+wuWA5hT1cZxCBRs0bU7Ow3jyLb97/pW1Yjt6H3pph7zKa+hFsT6Wct1r7IciaQ8QUhvzxCof3sJEnJZERL/LnLGrfbjkmdw6wZ0PJjSD5cmwGKFvLpslT/OYwc5M3fbmmFmVDJWRvQdE=" ;
encodeSyndromePosOffset = "x5gK5qlKM0HjrEEWOVHQX5VRqD0FtDWGqO/JP2ArcdR0yxE04pdR6B06J3iXbKv9CghrqvNiq+AlMAVWr/pm7bp5s3s+v5Bo3oYpQymmtd0FDKaZ4GQhi9yDu0Vm22j0Cllf5fLPFixhRMCBN/3S3t8IeHtVfmo5Vw0icN7OTHo=" ;
encodeSyndromeNegOffset = "wDLTEG5XPVhGlH8fuucGl8St2G/jGLyN3dByVGzOWeZ0CzI1M9jJq4DLj8A3XsMh8u80yvCq36SHXU+iO5cpVcfyiu08pqO1PjPUynqQa/aOcjbFhwjaEZePD42rQCBVdhViBeBEYzMhCTKroorw/Tt0AFC+NlRCMOsUmzSlsRU=" ;
encodeSyndrome1 = "YJNmzBE8sVjyo1l59bs/6I+Kqb4PRwEWY34ZHS/yKY5P+AzgGYtQrDplinhvvDKkjMpKOJm6iYplMDQ6OnR0ZwrzJv39czortUxnzOsjIxmzYtdszjDV6jFf/lA8+3lTS2veoTxIJ1a46z9+5hIbAthejftqYB8h9/PAk5PfWDk=" ;
2011-10-27 20:50:11 +00:00
encodeParity [ 8 ] = "jvR9QJ1cSWpqbyP0I0tBrBkQRjCDTDDQkttZGj14ROvsXyg+AnnxVKxL7gwLZbrQmTw5ZPps1Q3744g94qaOOQ==" ;
encodeParity [ 16 ] = "gwln1GxlYWH/Jn74PreMLv4aFF2glkScSWVFlxMBx94v5D3/3wPx+2guRLquED0s9tOFikPLiSnAv0Xq8aIQ6Q==" ;
}
2010-02-18 21:14:35 +00:00
//
//Use ClassCleanup to run code after all tests in a class have run
//[ClassCleanup()]
//public static void MyClassCleanup()
//{
//}
//
//Use TestInitialize to run code before running each test
//[TestInitialize()]
//public void MyTestInitialize()
//{
//}
//
//Use TestCleanup to run code after each test has run
//[TestCleanup()]
//public void MyTestCleanup()
//{
//}
//
#endregion
2011-10-27 20:50:11 +00:00
[TestMethod()]
public void CDRepairEncodeSyndromeTest ( )
{
for ( int n = 4 ; n < = AccurateRipVerify . maxNpar ; n * = 2 )
{
2011-11-15 10:56:49 +00:00
Assert . AreEqual < string > ( Convert . ToBase64String ( Convert . FromBase64String ( encodeSyndrome ) , 0 , n * 2 * 4 ) , Convert . ToBase64String ( ParityToSyndrome . Syndrome2Bytes ( encode . AR . GetSyndrome ( n , 4 ) ) ) , "syndrome mismatch" ) ;
Assert . AreEqual < string > ( Convert . ToBase64String ( Convert . FromBase64String ( encodeSyndromePosOffset ) , 0 , n * 2 * 4 ) , Convert . ToBase64String ( ParityToSyndrome . Syndrome2Bytes ( encode . AR . GetSyndrome ( n , 4 , offset ) ) ) , "syndrome with offset mismatch" ) ;
Assert . AreEqual < string > ( Convert . ToBase64String ( Convert . FromBase64String ( encodeSyndromeNegOffset ) , 0 , n * 2 * 4 ) , Convert . ToBase64String ( ParityToSyndrome . Syndrome2Bytes ( encode . AR . GetSyndrome ( n , 4 , - offset ) ) ) , "syndrome with neg offset mismatch" ) ;
2011-10-27 20:50:11 +00:00
}
Assert . AreEqual < uint > ( 377539636 , encode . CRC ) ;
}
2011-11-15 10:56:49 +00:00
[TestMethod()]
public unsafe void CDRepairSyndrome2BytesTest ( )
{
var syndrome = encode . AR . GetSyndrome ( ) ;
CollectionAssert . AreEqual ( syndrome , ParityToSyndrome . Bytes2Syndrome ( stride , AccurateRipVerify . maxNpar , ParityToSyndrome . Syndrome2Bytes ( syndrome ) ) ) ;
}
2011-04-08 14:41:28 +00:00
/// <summary>
///A test for Write
///</summary>
[TestMethod()]
2011-10-27 20:50:11 +00:00
public void CDRepairEncodeParityTest ( )
2011-04-08 14:41:28 +00:00
{
2011-10-27 20:50:11 +00:00
for ( int n = 8 ; n < = AccurateRipVerify . maxNpar ; n * = 2 )
2011-10-26 05:09:37 +00:00
{
2011-11-15 10:56:49 +00:00
Assert . AreEqual < string > ( encodeParity [ n ] , Convert . ToBase64String ( ParityToSyndrome . Syndrome2Parity ( encode . AR . GetSyndrome ( n ) ) , 0 , 64 ) ) ;
2011-10-26 05:09:37 +00:00
}
2011-10-25 01:16:11 +00:00
Assert . AreEqual < uint > ( 377539636 , encode . CRC ) ;
2011-04-08 14:41:28 +00:00
}
2010-02-18 21:14:35 +00:00
2011-10-25 01:16:11 +00:00
/// <summary>
2010-02-18 21:14:35 +00:00
///Verifying rip that is accurate
///</summary>
[TestMethod()]
public void CDRepairDecodeOriginalTest ( )
{
2011-10-27 20:50:11 +00:00
var decode = generator . CreateCDRepairEncode ( stride ) ;
2010-02-23 15:15:08 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( decode . FindOffset ( encode . AR . GetSyndrome ( ) , encode . CRC , out actualOffset , out hasErrors ) ) ;
2011-10-26 05:09:37 +00:00
Assert . IsFalse ( hasErrors , "has errors" ) ;
Assert . AreEqual ( 0 , actualOffset , "wrong offset" ) ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( decode . FindOffset ( encode . AR . GetSyndrome ( 8 ) , encode . CRC , out actualOffset , out hasErrors ) ) ;
Assert . IsFalse ( hasErrors , "has errors" ) ;
Assert . AreEqual ( 0 , actualOffset , "wrong offset" ) ;
}
2010-02-18 21:14:35 +00:00
/// <summary>
///Verifying rip that has errors
///</summary>
[TestMethod()]
public void CDRepairDecodeModifiedTest ( )
{
2011-04-08 14:41:28 +00:00
var generator2 = new TestImageGenerator ( "0 9801" , seed , 32 * 588 , errors ) ;
2011-10-27 20:50:11 +00:00
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
2010-02-23 15:15:08 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( decode . FindOffset ( encode . AR . GetSyndrome ( ) , encode . CRC , out actualOffset , out hasErrors ) ) ;
2010-02-23 15:15:08 +00:00
Assert . IsTrue ( hasErrors , "doesn't have errors" ) ;
Assert . AreEqual ( 0 , actualOffset , "wrong offset" ) ;
2011-11-15 10:56:49 +00:00
CDRepairFix fix = decode . VerifyParity ( encode . AR . GetSyndrome ( ) , encode . CRC , actualOffset ) ;
2010-02-23 15:15:08 +00:00
Assert . IsTrue ( fix . HasErrors , "doesn't have errors" ) ;
Assert . IsTrue ( fix . CanRecover , "cannot recover" ) ;
2011-04-08 14:41:28 +00:00
generator2 . Write ( fix ) ;
Assert . AreEqual < uint > ( encode . CRC , fix . CRC ) ;
2010-02-18 21:14:35 +00:00
}
/// <summary>
///Verifying rip that has positive offset
///</summary>
[TestMethod()]
public void CDRepairDecodePositiveOffsetTest ( )
{
2011-04-08 14:41:28 +00:00
var generator2 = new TestImageGenerator ( "0 9801" , seed , 32 * 588 + offset , 0 ) ;
2011-10-27 20:50:11 +00:00
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
2010-02-23 15:15:08 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( decode . FindOffset ( encode . AR . GetSyndrome ( ) , encode . CRC , out actualOffset , out hasErrors ) ) ;
2011-10-26 05:09:37 +00:00
Assert . IsFalse ( hasErrors , "has errors" ) ;
Assert . AreEqual ( offset , actualOffset , "wrong offset" ) ;
2010-02-18 21:14:35 +00:00
}
/// <summary>
///Verifying rip that has negative offset
///</summary>
[TestMethod()]
public void CDRepairDecodeNegativeOffsetTest ( )
{
2011-04-08 14:41:28 +00:00
var generator2 = new TestImageGenerator ( "0 9801" , seed , 32 * 588 - offset , 0 ) ;
2011-10-27 20:50:11 +00:00
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
2010-02-23 15:15:08 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( decode . FindOffset ( encode . AR . GetSyndrome ( ) , encode . CRC , out actualOffset , out hasErrors ) ) ;
2011-10-26 05:09:37 +00:00
Assert . IsFalse ( hasErrors , "has errors" ) ;
Assert . AreEqual ( - offset , actualOffset , "wrong offset" ) ;
2010-02-18 21:14:35 +00:00
}
/// <summary>
///Verifying rip that has errors and positive offset
///</summary>
[TestMethod()]
public void CDRepairDecodePositiveOffsetErrorsTest ( )
{
2011-04-08 14:41:28 +00:00
var generator2 = new TestImageGenerator ( "0 9801" , seed , 32 * 588 + offset , errors ) ;
2011-10-27 20:50:11 +00:00
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
2010-02-23 15:15:08 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
var syn = encode . AR . GetSyndrome ( ) ;
2011-10-26 05:09:37 +00:00
Assert . IsTrue ( decode . FindOffset ( syn , encode . CRC , out actualOffset , out hasErrors ) ) ;
Assert . IsTrue ( hasErrors , "doesn't have errors" ) ;
Assert . AreEqual ( offset , actualOffset , "wrong offset" ) ;
2011-11-15 10:56:49 +00:00
CDRepairFix fix = decode . VerifyParity ( syn , encode . CRC , actualOffset ) ;
2011-10-26 05:09:37 +00:00
Assert . IsTrue ( fix . HasErrors , "doesn't have errors" ) ;
Assert . IsTrue ( fix . CanRecover , "cannot recover" ) ;
generator2 . Write ( fix ) ;
Assert . AreEqual < uint > ( encode . CRC , fix . CRC ) ;
2010-02-18 21:14:35 +00:00
}
/// <summary>
///Verifying rip that has errors and negative offset
///</summary>
[TestMethod()]
public void CDRepairDecodeNegativeOffsetErrorsTest ( )
{
2011-04-09 13:24:34 +00:00
var generator2 = new TestImageGenerator ( "0 999 9801" , seed , 32 * 588 - offset , errors ) ;
2011-10-27 20:50:11 +00:00
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
2010-02-23 15:15:08 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( decode . FindOffset ( encode . AR . GetSyndrome ( ) , encode . CRC , out actualOffset , out hasErrors ) , "couldn't find offset" ) ;
2010-02-23 15:15:08 +00:00
Assert . IsTrue ( hasErrors , "doesn't have errors" ) ;
Assert . AreEqual ( - offset , actualOffset , "wrong offset" ) ;
2011-11-15 10:56:49 +00:00
var fix = decode . VerifyParity ( encode . AR . GetSyndrome ( ) , encode . CRC , actualOffset ) ;
2010-02-23 15:15:08 +00:00
Assert . IsTrue ( fix . HasErrors , "doesn't have errors" ) ;
Assert . IsTrue ( fix . CanRecover , "cannot recover" ) ;
2011-04-08 14:41:28 +00:00
generator2 . Write ( fix ) ;
Assert . AreEqual < uint > ( encode . CRC , fix . CRC ) ;
2011-10-27 20:50:11 +00:00
if ( AccurateRipVerify . maxNpar > 8 )
{
2011-11-15 10:56:49 +00:00
fix = decode . VerifyParity ( encode . AR . GetSyndrome ( 8 ) , encode . CRC , actualOffset ) ;
2011-10-27 20:50:11 +00:00
Assert . IsTrue ( fix . HasErrors , "doesn't have errors" ) ;
Assert . IsTrue ( fix . CanRecover , "cannot recover" ) ;
generator2 . Write ( fix ) ;
Assert . AreEqual < uint > ( encode . CRC , fix . CRC ) ;
}
}
2011-04-17 02:07:13 +00:00
2011-04-24 21:07:50 +00:00
[TestMethod]
public void GFMiscTest ( )
{
var g16 = Galois16 . instance ;
CollectionAssert . AreEqual ( new int [ ] { 5 , 33657 , 33184 , 33657 , 5 } , g16 . gfconv ( new int [ ] { 1 , 2 , 3 } , new int [ ] { 4 , 3 , 2 } ) ) ;
CollectionAssert . AreEqual ( new int [ ] { 5 , 6 , 1774 , 4 , 5 } , g16 . gfconv ( new int [ ] { 1 , 2 , 3 } , new int [ ] { 4 , - 1 , 2 } ) ) ;
2011-04-17 02:07:13 +00:00
2011-04-24 21:07:50 +00:00
var g8 = Galois81D . instance ;
Assert . AreEqual ( 111 , g8 . gfadd ( 11 , 15 ) ) ;
Assert . AreEqual ( 11 , g8 . gfadd ( 11 , - 1 ) ) ;
Assert . AreEqual ( 25 , g8 . gfadd ( 1 , 0 ) ) ;
var S = new int [ 8 ] { - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 , - 1 } ;
var received = new int [ ] { 2 , 4 , 1 , 3 , 5 } ;
for ( int ii = 0 ; ii < 8 ; ii + + )
for ( int x = 0 ; x < 5 ; x + + )
S [ ii ] = g8 . gfadd ( S [ ii ] , g8 . gfmul ( received [ x ] , g8 . gfpow ( ii + 1 , x ) ) ) ;
CollectionAssert . AreEqual ( S , new int [ ] { 219 , 96 , 208 , 202 , 116 , 211 , 182 , 129 } ) ;
//S[ii] ^= received[x] * a ^ ((ii + 1) * x);
//S[0] ^= received[0] * a ^ (1 * 0);
//S[0] ^= received[1] * a ^ (1 * 1);
//S[0] ^= received[2] * a ^ (1 * 2);
//S[1] ^= received[0] * a ^ (2 * 0);
//S[1] ^= received[1] * a ^ (2 * 1);
//S[1] ^= received[2] * a ^ (2 * 2);
received = g8 . toExp ( received ) ;
for ( int ii = 0 ; ii < 8 ; ii + + )
{
S [ ii ] = 0 ;
for ( int x = 0 ; x < 5 ; x + + )
S [ ii ] ^ = g8 . mulExp ( received [ x ] , ( ( ii + 1 ) * x ) % 255 ) ;
}
S = g8 . toLog ( S ) ;
CollectionAssert . AreEqual ( S , new int [ ] { 219 , 96 , 208 , 202 , 116 , 211 , 182 , 129 } ) ;
}
/// <summary>
///A test for CRC parralelism
///</summary>
[TestMethod()]
2011-10-25 01:16:11 +00:00
//[Ignore]
2011-04-24 21:07:50 +00:00
public void CDRepairSplitTest ( )
{
var seed = 723722 ;
2011-10-27 20:50:11 +00:00
var ar0 = new TestImageGenerator ( "13 68 99 136" , seed , 0 , 0 ) . CreateCDRepairEncode ( stride ) ;
2011-04-24 21:07:50 +00:00
var splits = new int [ ] { 1 , 13 * 588 - 1 , 13 * 588 , 13 * 588 + 1 , 30 * 588 - 1 , 30 * 588 , 30 * 588 + 1 , 68 * 588 - 1 , 68 * 588 , 68 * 588 + 1 } ;
foreach ( int split in splits )
{
2011-11-15 10:56:49 +00:00
var ar1 = new TestImageGenerator ( "13 68 99 136" , seed , 0 , 0 , 0 , 0 , split ) . CreateCDRepairEncode ( stride ) ;
var ar2 = new TestImageGenerator ( "13 68 99 136" , seed , 0 , 0 , 0 , split , ( int ) ar0 . FinalSampleCount ) . CreateCDRepairEncode ( stride ) ;
2011-04-24 21:07:50 +00:00
ar1 . AR . Combine ( ar2 . AR , split , ( int ) ar0 . FinalSampleCount ) ;
2011-10-25 01:16:11 +00:00
string message = "split = " + CDImageLayout . TimeToString ( ( uint ) split / 588 ) + "." + ( split % 588 ) . ToString ( ) ;
2011-04-24 21:07:50 +00:00
Assert . AreEqual ( ar0 . CRC , ar1 . CRC , "CRC was not set correctly, " + message ) ;
2011-11-15 10:56:49 +00:00
CollectionAssert . AreEqual ( ar0 . AR . GetSyndrome ( ) , ar1 . AR . GetSyndrome ( ) , "Parity was not set correctly, " + message ) ;
2011-04-24 21:07:50 +00:00
}
}
/// <summary>
///A test for CRC parralelism speed
///</summary>
[TestMethod()]
public unsafe void CDRepairSplitSpeedTest ( )
{
var seed = 723722 ;
var split = 20 * 588 ;
2011-11-15 10:56:49 +00:00
var ar1 = new TestImageGenerator ( "13 68 99 136" , seed , 0 , 0 , 0 , 0 , split ) . CreateCDRepairEncode ( stride ) ;
var ar2 = new TestImageGenerator ( "13 68 99 136" , seed , 0 , 0 , 0 , split , ( int ) ar1 . FinalSampleCount ) . CreateCDRepairEncode ( stride ) ;
2011-04-24 21:07:50 +00:00
for ( int i = 0 ; i < 20 ; i + + )
ar1 . AR . Combine ( ar2 . AR , split , ( int ) ar1 . FinalSampleCount ) ;
}
/// <summary>
///A test for Syndrome2Parity speed
///</summary>
[TestMethod()]
public unsafe void CDRepairSyndrome2ParitySpeedTest ( )
{
2011-10-27 20:50:11 +00:00
var syndrome = encode . AR . GetSyndrome ( ) ;
2011-11-15 10:56:49 +00:00
byte [ ] parityCopy = ParityToSyndrome . Syndrome2Parity ( syndrome ) ;
2011-04-24 21:07:50 +00:00
for ( int t = 0 ; t < 100 ; t + + )
2011-10-25 01:16:11 +00:00
ParityToSyndrome . Syndrome2Parity ( syndrome , parityCopy ) ;
2011-11-15 10:56:49 +00:00
CollectionAssert . AreEqual ( syndrome , ParityToSyndrome . Parity2Syndrome ( syndrome . GetLength ( 0 ) , syndrome . GetLength ( 0 ) , syndrome . GetLength ( 1 ) , syndrome . GetLength ( 1 ) , parityCopy ) ) ;
2011-04-24 21:07:50 +00:00
}
[TestMethod]
public unsafe void CDRepairEncodeSynParTest ( )
{
2011-11-15 10:56:49 +00:00
var syndrome = encode . AR . GetSyndrome ( ) ;
var parityCopy = ParityToSyndrome . Syndrome2Parity ( syndrome ) ;
CollectionAssert . AreEqual ( syndrome , ParityToSyndrome . Parity2Syndrome ( syndrome . GetLength ( 0 ) , syndrome . GetLength ( 0 ) , syndrome . GetLength ( 1 ) , syndrome . GetLength ( 1 ) , parityCopy ) ) ;
2011-10-25 01:16:11 +00:00
}
2011-04-24 21:07:50 +00:00
[TestMethod]
public void CDRepairEncodeSpeedTest ( )
{
var generator = new TestImageGenerator ( "0 75000" , seed , 0 , 0 ) ;
2011-10-27 20:50:11 +00:00
var encode = generator . CreateCDRepairEncode ( stride ) ;
2011-11-15 10:56:49 +00:00
Assert . AreEqual < string > ( Convert . ToBase64String ( Convert . FromBase64String ( encodeSyndrome1 ) , 0 , AccurateRipVerify . maxNpar * 2 * 4 ) ,
Convert . ToBase64String ( ParityToSyndrome . Syndrome2Bytes ( encode . AR . GetSyndrome ( AccurateRipVerify . maxNpar , 4 ) ) ) , "syndrome mismatch" ) ;
2011-04-24 21:07:50 +00:00
}
2011-05-15 17:41:14 +00:00
2011-11-15 10:56:49 +00:00
/// <summary>
/// Verifying a very long rip.
/// </summary>
[TestMethod()]
[Ignore]
public void CDRepairVerifyParityLongTest ( )
{
var generator1 = new TestImageGenerator ( "0 655000" , seed ) ;
var encode1 = generator1 . CreateCDRepairEncode ( stride ) ;
var generator2 = new TestImageGenerator ( "0 655000" , seed , 0 , stride / 2 * 3 , 7 ) ;
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
int actualOffset ;
bool hasErrors ;
var syndrome = encode1 . AR . GetSyndrome ( ) ;
Assert . IsTrue ( decode . FindOffset ( syndrome , encode1 . CRC , out actualOffset , out hasErrors ) ) ;
Assert . IsTrue ( hasErrors , "doesn't have errors" ) ;
Assert . AreEqual ( 0 , actualOffset , "wrong offset" ) ;
CDRepairFix fix = decode . VerifyParity ( syndrome , encode1 . CRC , actualOffset ) ;
Assert . IsTrue ( fix . HasErrors , "doesn't have errors" ) ;
Assert . IsTrue ( fix . CanRecover , "cannot recover" ) ;
}
2011-05-15 17:41:14 +00:00
/// <summary>
///Verifying rip that has errors
///</summary>
[TestMethod()]
2012-01-07 00:17:00 +00:00
[Ignore]
2011-05-15 17:41:14 +00:00
public void CDRepairVerifyParitySpeedTest ( )
{
2011-11-15 10:56:49 +00:00
var generator1 = new TestImageGenerator ( "0 98011" , seed , 32 * 588 ) ;
2011-10-27 20:50:11 +00:00
var encode1 = generator1 . CreateCDRepairEncode ( stride ) ;
2011-11-15 10:56:49 +00:00
var generator2 = new TestImageGenerator ( "0 98011" , seed , 32 * 588 , stride / 2 * 3 , 7 ) ;
//var generator2 = new TestImageGenerator("0 98011", seed, 32 * 588, stride, 7);
2011-10-27 20:50:11 +00:00
var decode = generator2 . CreateCDRepairEncode ( stride ) ;
2011-05-15 17:41:14 +00:00
int actualOffset ;
bool hasErrors ;
2011-10-27 20:50:11 +00:00
var syndrome = encode1 . AR . GetSyndrome ( ) ;
Assert . IsTrue ( decode . FindOffset ( syndrome , encode1 . CRC , out actualOffset , out hasErrors ) ) ;
2011-05-15 17:41:14 +00:00
Assert . IsTrue ( hasErrors , "doesn't have errors" ) ;
Assert . AreEqual ( 0 , actualOffset , "wrong offset" ) ;
2011-11-15 10:56:49 +00:00
for ( int t = 0 ; t < 100 ; t + + )
decode . VerifyParity ( syndrome , encode1 . CRC , actualOffset ) ;
CDRepairFix fix = decode . VerifyParity ( syndrome , encode1 . CRC , actualOffset ) ;
2011-05-15 17:41:14 +00:00
Assert . IsTrue ( fix . HasErrors , "doesn't have errors" ) ;
Assert . IsTrue ( fix . CanRecover , "cannot recover" ) ;
2011-11-15 10:56:49 +00:00
//generator2.Write(fix);
//Assert.AreEqual<uint>(encode1.CRC, fix.CRC);
//var encodeTable = Galois16.instance.makeEncodeTable(16);
//using (StreamWriter sr = new StreamWriter(@"D:\Work\cuetoolsnet\CUETools\x64\Release\ddd"))
//{
// for (int i = 0; i < encodeTable.GetLength(0) * encodeTable.GetLength(1) * encodeTable.GetLength(2); i++)
// {
// if ((i % 16) == 0)
// sr.WriteLine();
// sr.Write(string.Format("0x{0:X4}, ", pte[i]));
// }
// sr.Close();
// throw new Exception("aa");
//}
}
2010-02-18 21:14:35 +00:00
}
}