forked from gadial/ECC
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathprimes.h
41 lines (35 loc) · 1.42 KB
/
primes.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/*
* File: primes.h
* Author: gadial
*
* Created on November 5, 2009, 2:47 PM
*/
#ifndef _PRIMES_H
#define _PRIMES_H
#include <gmpxx.h>
#include "zp_int.h"
class RandomNumberGenerator{ //naive. very naive
public:
RandomNumberGenerator(unsigned long seed = 0);
mpz_class rand(mpz_class max);
mpz_class rand_binary_digits(int binary_digits);
//generates a random prime not larger than 2^n-1
mpz_class generate_prime(unsigned long int n);
mpz_class generate_prime_for_discriminant(unsigned long int n, mpz_class D, mpz_class& t, mpz_class& s);
zp_int generate_modulu_p(mpz_class p);
zp_int generate_qnr_modulu_p(mpz_class p);
private:
gmp_randstate_t state;
};
//returns 1 if n is a quadratic residue modulo a prime p, -1 if it is not, and 0 if p divides n
int legendre_symbol(mpz_class n, mpz_class p);
//returns 1 if a is a quadratic residue modulo an odd b, -1 if it is not, and 0 if b divides a
int jacobi_symbol(mpz_class a,mpz_class b);
//returns x such that x**2 = n. If none exists, returns 0
mpz_class modular_square_root(mpz_class n, mpz_class p);
zp_int modular_square_root(zp_int n);
bool is_near_prime(mpz_class p, int smoothness_allowed, mpz_class min_size_allowed);
bool is_near_prime_by_min_max(mpz_class p, mpz_class first_divisor_min, int second_divisor_max);
mpz_class mersenne_prime(int n);
bool extended_cornacchia(mpz_class p, int D, mpz_class& t,mpz_class& s);
#endif /* _PRIMES_H */