test/random_test.cc
author Peter Kovacs <kpeter@inf.elte.hu>
Sat, 25 Apr 2009 02:12:41 +0200
changeset 670 7c1324b35d89
parent 209 765619b7cbb2
child 1379 db1d342a1087
permissions -rw-r--r--
Modify the interface of Suurballe (#266, #181)

- Move the parameters s and t from the constructor to the run()
function. It makes the interface capable for multiple run(s,t,k)
calls (possible improvement in the future) and it is more similar
to Dijkstra.
- Simliarly init() and findFlow(k) were replaced by init(s) and
findFlow(t,k). The separation of parameters s and t is for the
future plans of supporting multiple targets with one source node.
For more information see #181.
- LEMON_ASSERT for the Length type (check if it is integer).
- Doc improvements.
- Rearrange query functions.
- Extend test file.
     1 /* -*- mode: C++; indent-tabs-mode: nil; -*-
     2  *
     3  * This file is a part of LEMON, a generic C++ optimization library.
     4  *
     5  * Copyright (C) 2003-2009
     6  * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
     7  * (Egervary Research Group on Combinatorial Optimization, EGRES).
     8  *
     9  * Permission to use, modify and distribute this software is granted
    10  * provided that this copyright notice appears in all copies. For
    11  * precise terms see the accompanying LICENSE file.
    12  *
    13  * This software is provided "AS IS" with no warranty of any kind,
    14  * express or implied, and with no claim as to its suitability for any
    15  * purpose.
    16  *
    17  */
    18 
    19 #include <lemon/random.h>
    20 #include "test_tools.h"
    21 
    22 int seed_array[] = {1, 2};
    23 
    24 int main()
    25 {
    26   double a=lemon::rnd();
    27   check(a<1.0&&a>0.0,"This should be in [0,1)");
    28   a=lemon::rnd.gauss();
    29   a=lemon::rnd.gamma(3.45,0);
    30   a=lemon::rnd.gamma(4);
    31   //Does gamma work with integer k?
    32   a=lemon::rnd.gamma(4.0,0);
    33   a=lemon::rnd.poisson(.5);
    34 
    35   lemon::rnd.seed(100);
    36   lemon::rnd.seed(seed_array, seed_array +
    37                   (sizeof(seed_array) / sizeof(seed_array[0])));
    38 
    39   return 0;
    40 }