New test.
[mono.git] / mcs / class / corlib / Mono.Math.Prime.Generator / PrimeGeneratorBase.cs
1 //
2 // Mono.Math.Prime.Generator.PrimeGeneratorBase.cs - Abstract Prime Generator
3 //
4 // Authors:
5 //      Ben Maurer
6 //
7 // Copyright (c) 2003 Ben Maurer. All rights reserved
8 //
9
10 //
11 // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
12 //
13 // Permission is hereby granted, free of charge, to any person obtaining
14 // a copy of this software and associated documentation files (the
15 // "Software"), to deal in the Software without restriction, including
16 // without limitation the rights to use, copy, modify, merge, publish,
17 // distribute, sublicense, and/or sell copies of the Software, and to
18 // permit persons to whom the Software is furnished to do so, subject to
19 // the following conditions:
20 // 
21 // The above copyright notice and this permission notice shall be
22 // included in all copies or substantial portions of the Software.
23 // 
24 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
28 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
29 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
30 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 //
32
33 using System;
34
35 namespace Mono.Math.Prime.Generator {
36
37 #if INSIDE_CORLIB
38         internal
39 #else
40         public
41 #endif
42         abstract class PrimeGeneratorBase {
43
44                 public virtual ConfidenceFactor Confidence {
45                         get {
46 #if DEBUG
47                                 return ConfidenceFactor.ExtraLow;
48 #else
49                                 return ConfidenceFactor.Medium;
50 #endif
51                         }
52                 }
53
54                 public virtual Prime.PrimalityTest PrimalityTest {
55                         get {
56                                 return new Prime.PrimalityTest (PrimalityTests.RabinMillerTest);
57                         }
58                 }
59
60                 public virtual int TrialDivisionBounds {
61                         get { return 4000; }
62                 }
63
64                 /// <summary>
65                 /// Performs primality tests on bi, assumes trial division has been done.
66                 /// </summary>
67                 /// <param name="bi">A BigInteger that has been subjected to and passed trial division</param>
68                 /// <returns>False if bi is composite, true if it may be prime.</returns>
69                 /// <remarks>The speed of this method is dependent on Confidence</remarks>
70                 protected bool PostTrialDivisionTests (BigInteger bi)
71                 {
72                         return PrimalityTest (bi, this.Confidence);
73                 }
74
75                 public abstract BigInteger GenerateNewPrime (int bits);
76         }
77 }