summaryrefslogtreecommitdiff
path: root/src/curve.c
blob: 0d15ccf3ac57c9f87839b54ae60d57d2d2f29c11 (plain)
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
/*
 * ecgen, tool for generating Elliptic curve domain parameters
 * Copyright (C) 2017 J08nY
 */
#include "curve.h"

GEN curve_random(GEN field) {
	pari_sp ltop = avma;

	GEN curve;
	do {
		GEN a = genrand(field);
		GEN b = genrand(field);

		GEN v = gen_0;
		switch (typ(field)) {
			case t_INT:
				v = gtovec0(gen_0, 2);
				gel(v, 1) = a;
				gel(v, 2) = b;
				break;
			case t_FFELT:
				v = gtovec0(gen_0, 5);
				gel(v, 1) = gen_1;
				gel(v, 4) = a;
				gel(v, 5) = b;
				break;
			default:
				pari_err_TYPE("curve_random", field);
		}
		curve = ellinit(v, field, -1);
	} while (gequal0(ell_get_disc(curve)));

	return gerepilecopy(ltop, curve);
}