INET Framework for OMNeT++/OMNEST
inet::physicallayer::NoiseDimensionalTransmitter Class Reference

#include <NoiseDimensionalTransmitter.h>

Inheritance diagram for inet::physicallayer::NoiseDimensionalTransmitter:
inet::physicallayer::TransmitterBase inet::physicallayer::DimensionalTransmitterBase inet::physicallayer::ITransmitter inet::IPrintableObject inet::IPrintableObject

Public Member Functions

virtual std::ostream & printToStream (std::ostream &stream, int level, int evFlags=0) const override
 Prints this object to the provided output stream. More...
 
virtual const ITransmissioncreateTransmission (const IRadio *radio, const Packet *packet, simtime_t startTime) const override
 Returns a transmission which describes the radio signal corresponding to the provided packet. More...
 
- Public Member Functions inherited from inet::physicallayer::TransmitterBase
virtual W getMaxPower () const override
 Returns the maximum transmission power above which no transmission is ever transmitted. More...
 
virtual m getMaxCommunicationRange () const override
 Returns the maximum communication range. More...
 
virtual m getMaxInterferenceRange () const override
 Returns the maximum interference range. More...
 
- Public Member Functions inherited from inet::IPrintableObject
virtual ~IPrintableObject ()
 
virtual std::string printToString () const
 
virtual std::string printToString (int level, int evFlags=0) const
 
virtual std::string getInfoStringRepresentation (int evFlags=0) const
 
virtual std::string getDetailStringRepresentation (int evFlags=0) const
 
virtual std::string getDebugStringRepresentation (int evFlags=0) const
 
virtual std::string getTraceStringRepresentation (int evFlags=0) const
 
virtual std::string getCompleteStringRepresentation (int evFlags=0) const
 

Protected Member Functions

virtual void initialize (int stage) override
 
- Protected Member Functions inherited from inet::physicallayer::TransmitterBase
virtual int numInitStages () const override
 
- Protected Member Functions inherited from inet::physicallayer::DimensionalTransmitterBase
template<typename T >
std::vector< GainEntry< T > > parseGains (const char *text) const
 
virtual void parseTimeGains (const char *text)
 
virtual void parseFrequencyGains (const char *text)
 
template<typename T >
const Ptr< const IFunction< double, Domain< T > > > normalize (const Ptr< const IFunction< double, Domain< T >>> &function, const char *normalization) const
 
virtual Ptr< const IFunction< double, Domain< simsec, Hz > > > createGainFunction (const simtime_t startTime, const simtime_t endTime, Hz centerFrequency, Hz bandwidth) const
 
virtual Ptr< const IFunction< WpHz, Domain< simsec, Hz > > > createPowerFunction (const simtime_t startTime, const simtime_t endTime, Hz centerFrequency, Hz bandwidth, W power) const
 

Protected Attributes

cPar * durationParameter = nullptr
 
cPar * centerFrequencyParameter = nullptr
 
cPar * bandwidthParameter = nullptr
 
cPar * powerParameter = nullptr
 
- Protected Attributes inherited from inet::physicallayer::DimensionalTransmitterBase
const IInterpolator< simsec, double > * firstTimeInterpolator = nullptr
 
const IInterpolator< Hz, double > * firstFrequencyInterpolator = nullptr
 
std::vector< GainEntry< simsec > > timeGains
 
std::vector< GainEntry< Hz > > frequencyGains
 
const char * timeGainsNormalization = nullptr
 
const char * frequencyGainsNormalization = nullptr
 
int gainFunctionCacheLimit = -1
 
std::map< std::tuple< simtime_t, Hz, Hz >, Ptr< const IFunction< double, Domain< simsec, Hz > > > > gainFunctionCache
 

Additional Inherited Members

- Public Types inherited from inet::IPrintableObject
enum  PrintLevel {
  PRINT_LEVEL_TRACE, PRINT_LEVEL_DEBUG, PRINT_LEVEL_DETAIL, PRINT_LEVEL_INFO,
  PRINT_LEVEL_COMPLETE = INT_MIN
}
 
enum  PrintFlag { PRINT_FLAG_FORMATTED = (1 << 0), PRINT_FLAG_MULTILINE = (1 << 1) }
 

Member Function Documentation

◆ createTransmission()

const ITransmission * inet::physicallayer::NoiseDimensionalTransmitter::createTransmission ( const IRadio transmitter,
const Packet packet,
simtime_t  startTime 
) const
overridevirtual

Returns a transmission which describes the radio signal corresponding to the provided packet.

This function never returns nullptr.

Implements inet::physicallayer::ITransmitter.

40 {
41  Hz centerFrequency = Hz(centerFrequencyParameter->doubleValue());
42  Hz bandwidth = Hz(bandwidthParameter->doubleValue());
43  W power = W(powerParameter->doubleValue());
44  const simtime_t duration = durationParameter->doubleValue();
45  const simtime_t endTime = startTime + duration;
46  IMobility *mobility = transmitter->getAntenna()->getMobility();
47  const Coord& startPosition = mobility->getCurrentPosition();
48  const Coord& endPosition = mobility->getCurrentPosition();
49  const Quaternion& startOrientation = mobility->getCurrentAngularPosition();
50  const Quaternion& endOrientation = mobility->getCurrentAngularPosition();
51  const Ptr<const IFunction<WpHz, Domain<simsec, Hz>>>& powerFunction = createPowerFunction(startTime, endTime, centerFrequency, bandwidth, power);
52  return new DimensionalTransmission(transmitter, nullptr, startTime, endTime, 0, 0, duration, startPosition, endPosition, startOrientation, endOrientation, nullptr, b(-1), b(-1), centerFrequency, bandwidth, bps(NaN), powerFunction);
53 }

◆ initialize()

void inet::physicallayer::NoiseDimensionalTransmitter::initialize ( int  stage)
overrideprotectedvirtual

Reimplemented from inet::physicallayer::DimensionalTransmitterBase.

21 {
22  TransmitterBase::initialize(stage);
24  if (stage == INITSTAGE_LOCAL) {
25  durationParameter = &par("duration");
26  centerFrequencyParameter = &par("centerFrequency");
27  bandwidthParameter = &par("bandwidth");
28  powerParameter = &par("power");
29  }
30 }

◆ printToStream()

std::ostream & inet::physicallayer::NoiseDimensionalTransmitter::printToStream ( std::ostream &  stream,
int  level,
int  evFlags = 0 
) const
overridevirtual

Prints this object to the provided output stream.

Reimplemented from inet::physicallayer::DimensionalTransmitterBase.

33 {
34  stream << "NoiseDimensionalTransmitter";
35  TransmitterBase::printToStream(stream, level);
36  return DimensionalTransmitterBase::printToStream(stream, level);
37 }

Member Data Documentation

◆ bandwidthParameter

cPar* inet::physicallayer::NoiseDimensionalTransmitter::bandwidthParameter = nullptr
protected

Referenced by createTransmission(), and initialize().

◆ centerFrequencyParameter

cPar* inet::physicallayer::NoiseDimensionalTransmitter::centerFrequencyParameter = nullptr
protected

Referenced by createTransmission(), and initialize().

◆ durationParameter

cPar* inet::physicallayer::NoiseDimensionalTransmitter::durationParameter = nullptr
protected

Referenced by createTransmission(), and initialize().

◆ powerParameter

cPar* inet::physicallayer::NoiseDimensionalTransmitter::powerParameter = nullptr
protected

Referenced by createTransmission(), and initialize().


The documentation for this class was generated from the following files:
inet::physicallayer::DimensionalTransmitterBase::printToStream
virtual std::ostream & printToStream(std::ostream &stream, int level, int evFlags=0) const override
Prints this object to the provided output stream.
Definition: DimensionalTransmitterBase.cc:110
inet::units::units::Hz
pow< s, -1 > Hz
Definition: Units.h:935
inet::physicallayer::NoiseDimensionalTransmitter::centerFrequencyParameter
cPar * centerFrequencyParameter
Definition: NoiseDimensionalTransmitter.h:23
inet::units::units::bps
compose< b, pow< s, -1 > > bps
Definition: Units.h:1169
inet::units::units::W
compose< J, pow< s, -1 > > W
Definition: Units.h:939
inet::physicallayer::DimensionalTransmitterBase::initialize
virtual void initialize(int stage)
Definition: DimensionalTransmitterBase.cc:20
inet::physicallayer::DimensionalTransmitterBase::createPowerFunction
virtual Ptr< const IFunction< WpHz, Domain< simsec, Hz > > > createPowerFunction(const simtime_t startTime, const simtime_t endTime, Hz centerFrequency, Hz bandwidth, W power) const
Definition: DimensionalTransmitterBase.cc:204
NaN
#define NaN
Definition: INETMath.h:91
inet::INITSTAGE_LOCAL
INET_API InitStage INITSTAGE_LOCAL
Initialization of local state that don't use or affect other modules includes:
inet::units::values::b
value< int64_t, units::b > b
Definition: Units.h:1241
inet::IPrintableObject::printToStream
virtual std::ostream & printToStream(std::ostream &stream, int level, int evFlags=0) const
Prints this object to the provided output stream.
Definition: IPrintableObject.h:40
inet::physicallayer::NoiseDimensionalTransmitter::powerParameter
cPar * powerParameter
Definition: NoiseDimensionalTransmitter.h:25
inet::physicallayer::NoiseDimensionalTransmitter::bandwidthParameter
cPar * bandwidthParameter
Definition: NoiseDimensionalTransmitter.h:24
inet::physicallayer::NoiseDimensionalTransmitter::durationParameter
cPar * durationParameter
Definition: NoiseDimensionalTransmitter.h:22