summaryrefslogtreecommitdiff
path: root/src/util/random.c
diff options
context:
space:
mode:
authorJ08nY2018-03-03 01:02:08 +0100
committerJ08nY2018-03-03 01:02:08 +0100
commitac60f78a253efde94cab36264b0555b0691fdd8a (patch)
tree12ce2bfdee1f13f0b6e56a017c3c29979475fe02 /src/util/random.c
parent40cbb213ac910ddcaf22a26a247d2a9eeddca1fc (diff)
downloadecgen-ac60f78a253efde94cab36264b0555b0691fdd8a.tar.gz
ecgen-ac60f78a253efde94cab36264b0555b0691fdd8a.tar.zst
ecgen-ac60f78a253efde94cab36264b0555b0691fdd8a.zip
Rewrite generator and point generation code.
Diffstat (limited to 'src/util/random.c')
-rw-r--r--src/util/random.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/util/random.c b/src/util/random.c
index 860cff0..eaeceaf 100644
--- a/src/util/random.c
+++ b/src/util/random.c
@@ -62,6 +62,16 @@ GEN random_int(unsigned long bits) {
return gerepilecopy(ltop, genrand(range));
}
+GEN random_range(GEN lower, GEN upper) {
+ pari_sp ltop = avma;
+ if (gequal(lower, upper)) {
+ return gcopy(lower);
+ }
+
+ GEN range = mkvec2(lower, subis(upper, 1));
+ return gerepilecopy(ltop, genrand(range));
+}
+
GEN random_field_element(GEN field) {
switch (typ(field)) {
case t_INT: