src/devices/wifi/random-stream.cc
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Mon, 05 Nov 2007 16:31:52 +0100
changeset 2066 4477ee7d0798
parent 1991 6527b3e26b86
child 4226 a08201e94eb2
permissions -rw-r--r--
test propagation losses
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1967
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     2
/*
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     3
 * Copyright (c) 2007 INRIA
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     4
 *
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     8
 *
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    12
 * GNU General Public License for more details.
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    13
 *
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    17
 *
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    19
 */
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    20
#include "random-stream.h"
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    21
#include "ns3/rng-stream.h"
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
#include "ns3/assert.h"
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    23
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    24
namespace ns3 {
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    25
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
RandomStream::~RandomStream ()
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
{}
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    29
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    30
RealRandomStream::RealRandomStream ()
1991
6527b3e26b86 fix valgrind warning: initialize RngStream correctly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1967
diff changeset
    31
{
6527b3e26b86 fix valgrind warning: initialize RngStream correctly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1967
diff changeset
    32
  m_stream.InitializeStream();
6527b3e26b86 fix valgrind warning: initialize RngStream correctly
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1967
diff changeset
    33
}
1967
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
uint32_t 
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    35
RealRandomStream::GetNext (uint32_t min, uint32_t max)
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    36
{
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    37
  return m_stream.RandInt (min, max);
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
}
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    39
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    41
void 
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
TestRandomStream::AddNext (uint32_t v)
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    43
{
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
  m_nexts.push_back (v);
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    45
}
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    47
uint32_t 
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
TestRandomStream::GetNext (uint32_t min, uint32_t max)
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
{
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    50
  NS_ASSERT (!m_nexts.empty ());
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    51
  uint32_t next = m_nexts.front ();
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    52
  m_nexts.pop_front ();
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    53
  return next;
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    54
}
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    55
5d75cfed946a add wrapper class around RngStream for testing.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    56
} // namespace ns3