diff options
author | mark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-09-29 22:18:01 +0000 |
---|---|---|
committer | mark@chromium.org <mark@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-09-29 22:18:01 +0000 |
commit | 05f9b688e319fcb092be0e06f7b72d39dd3113b3 (patch) | |
tree | 6d24be7f9b788bbebbff6b2349e51dec49034ce6 /base/rand_util.cc | |
parent | 86ec30d6710923cf1c193eb88b1e6251f831e0ef (diff) | |
download | chromium_src-05f9b688e319fcb092be0e06f7b72d39dd3113b3.zip chromium_src-05f9b688e319fcb092be0e06f7b72d39dd3113b3.tar.gz chromium_src-05f9b688e319fcb092be0e06f7b72d39dd3113b3.tar.bz2 |
Refactoring for portability:
- Move chrome/common/env_util to base/sys_info
- Move chrome/common/rand_util to base/rand_util (new), simplify its public
interface, and fix its implementation
Patch by Paweł Hajdan, Jr. <phajdan.jr@gmail.com>
http://codereview.chromium.org/4079
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2697 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/rand_util.cc')
-rw-r--r-- | base/rand_util.cc | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/base/rand_util.cc b/base/rand_util.cc new file mode 100644 index 0000000..89b5b32 --- /dev/null +++ b/base/rand_util.cc @@ -0,0 +1,47 @@ +// Copyright (c) 2008 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "base/rand_util.h" + +#include <math.h> + +#include "base/basictypes.h" +#include "base/logging.h" + +namespace { + +union uint64_splitter { + uint64 normal; + uint16 split[4]; +}; + +} // namespace + +namespace base { + +int RandInt(int min, int max) { + DCHECK(min <= max); + + uint64 range = static_cast<int64>(max) - min + 1; + uint64 number = base::RandUInt64(); + int result = min + static_cast<int>(number % range); + DCHECK(result >= min && result <= max); + return result; +} + +double RandDouble() { + uint64_splitter number; + number.normal = base::RandUInt64(); + + // Standard code based on drand48 would give only 48 bits of precision. + // We try to get maximum precision for IEEE 754 double (52 bits). + double result = ldexp(static_cast<double>(number.split[0] & 0xf), -52) + + ldexp(static_cast<double>(number.split[1]), -48) + + ldexp(static_cast<double>(number.split[2]), -32) + + ldexp(static_cast<double>(number.split[3]), -16); + DCHECK(result >= 0.0 && result < 1.0); + return result; +} + +} // namespace base |