epoc32/include/stdapis/boost/random/uniform_on_sphere.hpp
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@2
     1
/* boost random/uniform_on_sphere.hpp header file
williamr@2
     2
 *
williamr@2
     3
 * Copyright Jens Maurer 2000-2001
williamr@2
     4
 * Distributed under the Boost Software License, Version 1.0. (See
williamr@2
     5
 * accompanying file LICENSE_1_0.txt or copy at
williamr@2
     6
 * http://www.boost.org/LICENSE_1_0.txt)
williamr@2
     7
 *
williamr@2
     8
 * See http://www.boost.org for most recent version including documentation.
williamr@2
     9
 *
williamr@2
    10
 * $Id: uniform_on_sphere.hpp,v 1.11 2004/07/27 03:43:32 dgregor Exp $
williamr@2
    11
 *
williamr@2
    12
 * Revision history
williamr@2
    13
 *  2001-02-18  moved to individual header files
williamr@2
    14
 */
williamr@2
    15
williamr@2
    16
#ifndef BOOST_RANDOM_UNIFORM_ON_SPHERE_HPP
williamr@2
    17
#define BOOST_RANDOM_UNIFORM_ON_SPHERE_HPP
williamr@2
    18
williamr@2
    19
#include <vector>
williamr@2
    20
#include <algorithm>     // std::transform
williamr@2
    21
#include <functional>    // std::bind2nd, std::divides
williamr@2
    22
#include <boost/random/normal_distribution.hpp>
williamr@2
    23
williamr@2
    24
namespace boost {
williamr@2
    25
williamr@2
    26
template<class RealType = double, class Cont = std::vector<RealType> >
williamr@2
    27
class uniform_on_sphere
williamr@2
    28
{
williamr@2
    29
public:
williamr@2
    30
  typedef RealType input_type;
williamr@2
    31
  typedef Cont result_type;
williamr@2
    32
williamr@2
    33
  explicit uniform_on_sphere(int dim = 2) : _container(dim), _dim(dim) { }
williamr@2
    34
williamr@2
    35
  // compiler-generated copy ctor and assignment operator are fine
williamr@2
    36
williamr@2
    37
  void reset() { _normal.reset(); }
williamr@2
    38
williamr@2
    39
  template<class Engine>
williamr@2
    40
  const result_type & operator()(Engine& eng)
williamr@2
    41
  {
williamr@2
    42
    RealType sqsum = 0;
williamr@2
    43
    for(typename Cont::iterator it = _container.begin();
williamr@2
    44
        it != _container.end();
williamr@2
    45
        ++it) {
williamr@2
    46
      RealType val = _normal(eng);
williamr@2
    47
      *it = val;
williamr@2
    48
      sqsum += val * val;
williamr@2
    49
    }
williamr@2
    50
#ifndef BOOST_NO_STDC_NAMESPACE
williamr@2
    51
    using std::sqrt;
williamr@2
    52
#endif
williamr@2
    53
    // for all i: result[i] /= sqrt(sqsum)
williamr@2
    54
    std::transform(_container.begin(), _container.end(), _container.begin(),
williamr@2
    55
                   std::bind2nd(std::divides<RealType>(), sqrt(sqsum)));
williamr@2
    56
    return _container;
williamr@2
    57
  }
williamr@2
    58
williamr@2
    59
#if !defined(BOOST_NO_OPERATORS_IN_NAMESPACE) && !defined(BOOST_NO_MEMBER_TEMPLATE_FRIENDS)
williamr@2
    60
  template<class CharT, class Traits>
williamr@2
    61
  friend std::basic_ostream<CharT,Traits>&
williamr@2
    62
  operator<<(std::basic_ostream<CharT,Traits>& os, const uniform_on_sphere& sd)
williamr@2
    63
  {
williamr@2
    64
    os << sd._dim;
williamr@2
    65
    return os;
williamr@2
    66
  }
williamr@2
    67
williamr@2
    68
  template<class CharT, class Traits>
williamr@2
    69
  friend std::basic_istream<CharT,Traits>&
williamr@2
    70
  operator>>(std::basic_istream<CharT,Traits>& is, uniform_on_sphere& sd)
williamr@2
    71
  {
williamr@2
    72
    is >> std::ws >> sd._dim;
williamr@2
    73
    sd._container.resize(sd._dim);
williamr@2
    74
    return is;
williamr@2
    75
  }
williamr@2
    76
#endif
williamr@2
    77
williamr@2
    78
private:
williamr@2
    79
  normal_distribution<RealType> _normal;
williamr@2
    80
  result_type _container;
williamr@2
    81
  int _dim;
williamr@2
    82
};
williamr@2
    83
williamr@2
    84
} // namespace boost
williamr@2
    85
williamr@2
    86
#endif // BOOST_RANDOM_UNIFORM_ON_SPHERE_HPP