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 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
|
// Cyphesis Online RPG Server and AI Engine
// Copyright (C) 2004 Alistair Riddoch
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program 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 this program; if not, write to the Free Software Foundation,
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
// $Id: randomtest.cpp,v 1.4 2007-04-23 11:33:41 alriddoch Exp $
#include "common/random.h"
#include <algorithm>
#include <iostream>
#include <cassert>
int main()
{
int int1 = randint(-2000000, 2000000);
int int2 = randint(-2000000, 2000000);
int previ = randint(std::min(int1, int2), std::max(int1, int2));
assert(int1 != int2);
assert(previ != int1);
assert(previ != int2);
float float1 = uniform(-2000000.f, 2000000.f);
float float2 = uniform(-2000000.f, 2000000.f);
float prevf = uniform(std::min(float1, float2), std::max(float1, float2));
assert(float1 != float2);
assert(prevf != float1);
assert(prevf != float2);
for (int i = 0; i < 1000; ++i) {
int1 = randint(-2000000, 2000000);
int2 = randint(-2000000, 2000000);
assert(int1 != int2);
float1 = uniform(-2000000.f, 2000000.f);
float2 = uniform(-2000000.f, 2000000.f);
assert(float1 != float2);
int num = randint(std::min(int1, int2), std::max(int1, int2));
std::cout << num << ":" << previ << " " << int1 << ":" << int2
<< std::endl << std::flush;
assert(num != int1);
assert(num != int2);
assert(num != previ);
assert(num > std::min(int1, int2));
assert(num < std::max(int1, int2));
previ = num;
float fl = uniform(std::min(float1, float2), std::max(float1, float2));
assert(fl != prevf);
assert(fl != float1);
assert(fl != float2);
assert(fl > std::min(float1, float2));
assert(fl < std::max(float1, float2));
prevf = fl;
}
}
|