Jo Shields a575963da9 Imported Upstream version 3.6.0
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
2014-08-13 10:39:27 +01:00

116 lines
2.7 KiB
C#

//
// MonoTests.Mono.Math.GcdBigTest.cs
//
// Authors:
// Ben Maurer
//
// Copyright (c) 2003 Ben Maurer. All rights reserved
//
using System;
using Mono.Math;
using NUnit.Framework;
namespace MonoTests.Mono.Math {
public abstract class GcdBig_Base : BigIntegerTestSet {
BigInteger A, B, aGcdB;
public GcdBig_Base()
{
A = new BigInteger(a);
B = new BigInteger(b);
aGcdB = new BigInteger(ExpectedAgcdB);
}
public abstract uint[] a {
get;
}
public abstract uint[] b {
get;
}
public abstract uint[] ExpectedAgcdB {
get;
}
[Test]
public void GcdPP()
{
Expect (A.GCD (B), aGcdB);
}
}
public class GcdBig_Rand2048a512b : GcdBig_Base {
public override uint[] a {
get {
return new uint[] {
0xaae18fa1, 0x58e1e9fc, 0x836350a0, 0x23d2a12d, 0x1aec1bdc, 0xad4a3b30,
0x40dc1d27, 0x625277fb, 0xddfbee25, 0xc1820dac, 0x4418603a, 0x5aec122c,
0x58b70181, 0x129d6b33, 0x6c4ed37e, 0x70808dd0, 0xed55b079, 0x706f15f3,
0x1a84b3ac, 0x088f1679, 0xcbf2be66, 0xb97a885e, 0xa2c95b95, 0xd44ebb83,
0x69351a38, 0x21d3cdb2, 0x30844c5c, 0x5abf8d7a, 0xb663c3de, 0x3ce2fcc5,
0x80b42a05, 0xa0a8aca3, 0x31d42948, 0x469d8ad5, 0xe0f66f7e, 0x3250dac1,
0xb4450067, 0xb247ad34, 0xbfd74c70, 0xfd1e29fa, 0x4050dc77, 0x827763b9,
0xba41410d, 0x42494b62, 0x99ef13a1, 0x55c957ec, 0x1e7dd0fc, 0x6c4cccdf,
0x981128e0, 0xc7c01688, 0x4ae5116c, 0x9b24d3c8, 0x623af290, 0x31ac1c1e,
0x0891f2f1, 0x678ab7ee, 0x6169af02, 0x2479511c, 0x7cea2114, 0xf13d541c,
0x0f54f253, 0xf5dd2553, 0xc0ea9613, 0x84a0c7b2
};
}
}
public override uint[] b {
get {
return new uint[] {
0x83ab64ef, 0x1350b335, 0xbf5f150d, 0x399a2487, 0xc1b76d63, 0xdf3e59ad,
0x2ed3b4fa, 0x9a6ad972, 0xb6e791c5, 0xdd7a8664, 0x802f8364, 0xf1a8617f,
0xb036a74a, 0x452ac130, 0x727e194f, 0x3dd8cfe8
};
}
}
public override uint[] ExpectedAgcdB {
get {
return new uint[] {
0x00000006
};
}
}
}
public class GcdBig_Rand512a512b : GcdBig_Base {
public override uint[] a {
get {
return new uint[] {
0x7bc1fb0e, 0x0335547e, 0x0e85b746, 0x1e7554d2, 0x77515958, 0xadf072c8,
0xdb03eb22, 0xdcedf7e2, 0x8f923f6a, 0xf124052d, 0x55d623f4, 0x29083f62,
0x66eaa78e, 0xfe819e63, 0xf8229bde, 0xe155c05b
};
}
}
public override uint[] b {
get {
return new uint[] {
0xe5320f2e, 0x379803d7, 0x24363d84, 0xfd61c43c, 0xa4e6ca6f, 0x16628f59,
0xddeb6557, 0xd904639c, 0x55f59c2f, 0x6ba21e54, 0x81107aa9, 0x47a4653c,
0xcc0a5889, 0xb6abcaec, 0xf6b58d60, 0xf8cc7eeb
};
}
}
public override uint[] ExpectedAgcdB {
get {
return new uint[] {
0x00000001
};
}
}
}
}