A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
threshold-preamble-detection-model.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 University of Washington
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Sébastien Deronne <sebastien.deronne@gmail.com>
18 */
19
20#ifndef THRESHOLD_PREAMBLE_DETECTION_MODEL_H
21#define THRESHOLD_PREAMBLE_DETECTION_MODEL_H
22
24
25namespace ns3
26{
27/**
28 * \ingroup wifi
29 *
30 * A threshold-based model for detecting PHY preamble.
31 * This model assumes that a preamble is successfully detected if SNR is at or above a given
32 * threshold (set to 4 dB by default). However, if RSSI is below a minimum RSSI (set to -82 dBm by
33 * default), the PHY preamble is not detected.
34 */
36{
37 public:
38 /**
39 * \brief Get the type ID.
40 * \return the object TypeId
41 */
42 static TypeId GetTypeId();
43
46
47 /**
48 * This method returns whether the preamble detection was successful.
49 *
50 * \param rssi the RSSI of the received signal (in Watts).
51 * \param snr the SNR ratio (linear scale) of the received signal.
52 * \param channelWidth the channel width of the received signal in MHz.
53 *
54 * \return true if the preamble has been detected,
55 * false otherwise
56 */
57 bool IsPreambleDetected(double rssi, double snr, double channelWidth) const override;
58
59 private:
60 double m_threshold; ///< SNR threshold in dB used to decide whether a preamble is successfully
61 ///< received
62 double m_rssiMin; ///< Minimum RSSI in dBm that shall be received to start the decision
63};
64
65} // namespace ns3
66
67#endif /* THRESHOLD_PREAMBLE_DETECTION_MODEL_H */
the interface for Wifi's preamble detection models
A threshold-based model for detecting PHY preamble.
double m_threshold
SNR threshold in dB used to decide whether a preamble is successfully received.
bool IsPreambleDetected(double rssi, double snr, double channelWidth) const override
This method returns whether the preamble detection was successful.
double m_rssiMin
Minimum RSSI in dBm that shall be received to start the decision.
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.