OpticalModulator.cc revision 10447
1 2#include "model/optical_graph/OpticalModulator.h" 3#include "model/optical_graph/OpticalTransmitter.h" 4 5namespace DSENT 6{ 7 OpticalModulator::OpticalModulator(const String& instance_name_, OpticalModel* model_, const WavelengthGroup& wavelengths_, bool opt_loss_, OpticalTransmitter* transmitter_) 8 : OpticalNode(OpticalNode::MODULATOR, instance_name_, model_, wavelengths_), m_transmitter_(transmitter_), m_insertion_loss_(0), m_extinction_ratio_(0), m_opt_loss_(opt_loss_) 9 { 10 11 } 12 13 OpticalModulator::~OpticalModulator() 14 { 15 16 } 17 18 bool OpticalModulator::canOptimizeLoss() const 19 { 20 return m_opt_loss_; 21 } 22 23 void OpticalModulator::setLosses(double IL_dB_, double ER_dB_) 24 { 25 m_insertion_loss_ = IL_dB_; 26 m_extinction_ratio_ = ER_dB_; 27 28 return; 29 } 30 31 bool OpticalModulator::setModulatorSpec(double IL_dB_, double ER_dB_) 32 { 33 // Ask the transmitter to design to those specs, returns success or fail 34 return m_transmitter_->setTransmitterSpec(IL_dB_, ER_dB_); 35 } 36 37 double OpticalModulator::getPower(double util_) const 38 { 39 return m_transmitter_->getPower(util_); 40 } 41 42 double OpticalModulator::getInsertionLoss() const 43 { 44 return m_insertion_loss_; 45 } 46 47 double OpticalModulator::getExtinctionRatio() const 48 { 49 return m_extinction_ratio_; 50 } 51 52} // namespace DSENT 53 54 55