~ubuntu-branches/ubuntu/trusty/travis/trusty-proposed

« back to all changes in this revision

Viewing changes to src/random.h

  • Committer: Package Import Robot
  • Author(s): Daniel Leidert
  • Date: 2014-01-18 20:07:16 UTC
  • mfrom: (1.1.8)
  • Revision ID: package-import@ubuntu.com-20140118200716-whsmcg7fa1eyqecq
Tags: 140117-1
New upstream release.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*****************************************************************************
2
 
    TRAVIS - Trajectory Analyzer and Visualizer
3
 
    http://www.travis-analyzer.de/
4
 
 
5
 
    Copyright (c) 2009-2013 Martin Brehm
6
 
                  2012-2013 Martin Thomas
7
 
 
8
 
    This file written by Martin Brehm.
9
 
 
10
 
    This program is free software: you can redistribute it and/or modify
11
 
    it under the terms of the GNU General Public License as published by
12
 
    the Free Software Foundation, either version 3 of the License, or
13
 
    (at your option) any later version.
14
 
 
15
 
    This program is distributed in the hope that it will be useful,
16
 
    but WITHOUT ANY WARRANTY; without even the implied warranty of
17
 
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18
 
    GNU General Public License for more details.
19
 
 
20
 
    You should have received a copy of the GNU General Public License
21
 
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
22
 
*****************************************************************************/
23
 
 
24
 
#ifndef RANDOM_H
25
 
#define RANDOM_H
26
 
 
27
 
 
28
 
#include "xobject.h"
29
 
#include "ziggurat.h"
30
 
#include <stdlib.h>
31
 
 
32
 
 
33
 
class CRandom : public CxObject
34
 
{
35
 
public:
36
 
        CRandom();
37
 
        ~CRandom();
38
 
 
39
 
        float RandomUniform()
40
 
        {
41
 
//              return r4_uni(&seed);
42
 
                return ((float)(rand()%RAND_MAX)/RAND_MAX/RAND_MAX) + ((float)(rand()%RAND_MAX)/RAND_MAX);
43
 
        }
44
 
 
45
 
        float RandomNormal()
46
 
        {
47
 
                return r4_nor(&seed,kn,fn,wn);
48
 
        }
49
 
 
50
 
        float RandomExp()
51
 
        {
52
 
                return r4_exp(&seed,ke,fe,we);
53
 
        }
54
 
 
55
 
        float fn[128];
56
 
        int kn[128];
57
 
        float wn[128];
58
 
        float fe[256];
59
 
        int ke[256];
60
 
        float we[256];
61
 
        unsigned long int seed;
62
 
};
63
 
 
64
 
#endif
 
1
/*****************************************************************************
 
2
    TRAVIS - Trajectory Analyzer and Visualizer
 
3
    http://www.travis-analyzer.de/
 
4
 
 
5
    Copyright (c) 2009-2014 Martin Brehm
 
6
                  2012-2014 Martin Thomas
 
7
 
 
8
    This file written by Martin Brehm.
 
9
 
 
10
    This program is free software: you can redistribute it and/or modify
 
11
    it under the terms of the GNU General Public License as published by
 
12
    the Free Software Foundation, either version 3 of the License, or
 
13
    (at your option) any later version.
 
14
 
 
15
    This program is distributed in the hope that it will be useful,
 
16
    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
17
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
18
    GNU General Public License for more details.
 
19
 
 
20
    You should have received a copy of the GNU General Public License
 
21
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
22
*****************************************************************************/
 
23
 
 
24
#ifndef RANDOM_H
 
25
#define RANDOM_H
 
26
 
 
27
 
 
28
#include "xobject.h"
 
29
#include "ziggurat.h"
 
30
#include <stdlib.h>
 
31
 
 
32
 
 
33
class CRandom : public CxObject
 
34
{
 
35
public:
 
36
        CRandom();
 
37
        ~CRandom();
 
38
 
 
39
        float RandomUniform()
 
40
        {
 
41
//              return r4_uni(&seed);
 
42
                return ((float)(rand()%RAND_MAX)/RAND_MAX/RAND_MAX) + ((float)(rand()%RAND_MAX)/RAND_MAX);
 
43
        }
 
44
 
 
45
        float RandomNormal()
 
46
        {
 
47
                return r4_nor(&seed,kn,fn,wn);
 
48
        }
 
49
 
 
50
        float RandomExp()
 
51
        {
 
52
                return r4_exp(&seed,ke,fe,we);
 
53
        }
 
54
 
 
55
        float fn[128];
 
56
        int kn[128];
 
57
        float wn[128];
 
58
        float fe[256];
 
59
        int ke[256];
 
60
        float we[256];
 
61
        unsigned long int seed;
 
62
};
 
63
 
 
64
#endif