File: latte_random.cpp

package info (click to toggle)
latte-int 1.7.6%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 38,260 kB
  • sloc: cpp: 32,231; sh: 4,413; makefile: 811; perl: 300
file content (46 lines) | stat: -rw-r--r-- 1,221 bytes parent folder | download
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
41
42
43
44
45
46
/* latte_random.cpp -- Interface to random number generators

   Copyright 2006 Matthias Koeppe

   This file is part of LattE.
   
   LattE is free software; you can redistribute it and/or modify it
   under the terms of the version 2 of the GNU General Public License
   as published by the Free Software Foundation.

   LattE is distributed in the hope that it will be useful, but
   WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with LattE; if not, write to the Free Software Foundation,
   Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*/

#include <stdlib.h>
#include "latte_random.h"

void
seed_random_generator(unsigned int seed)
{
  srand(seed);
  // Also seed NTL's pseudo-random generator.
  ZZ z_seed;
  z_seed = seed;
  SetSeed(z_seed);
}

int
uniform_random_number(int from, int to)
{
  int range = to - from + 1;
  return from + (int) ((double)range * rand()/(RAND_MAX+1.0));
}

ZZ
uniform_random_number(ZZ from, ZZ to)
{
  ZZ range = to - from + 1;
  return from + RandomBnd(range);
}