gem5/ext/dsent/model/optical_graph/OpticalDetector.cc
Nilay Vaish e8ed7b1d1b ext: add the source code for DSENT
This patch adds a tool called DSENT to the ext/ directory.  DSENT
is a tool that models power and area for on-chip networks.  The next
patch adds a script for using the tool.
2014-10-11 15:02:23 -05:00

33 lines
930 B
C++

#include "model/optical_graph/OpticalDetector.h"
#include "model/optical_graph/OpticalReceiver.h"
namespace DSENT
{
OpticalDetector::OpticalDetector(const String& instance_name_, OpticalModel* model_, const WavelengthGroup& wavelengths_, OpticalReceiver* receiver_)
: OpticalNode(OpticalNode::DETECTOR, instance_name_, model_, wavelengths_), m_receiver_(receiver_), m_responsivity_(0)
{
m_sensitivity_ = 0.0;
}
OpticalDetector::~OpticalDetector()
{
}
void OpticalDetector::setResponsivity(double responsivity_)
{
m_responsivity_ = responsivity_;
return;
}
double OpticalDetector::getSensitivity(double ER_dB_) const
{
// Get responsivity (in Amps) of the receiver, divide by responsivity to get sensitivity in Watts
return m_receiver_->getSensitivity(ER_dB_) / m_responsivity_;
}
} // namespace DSENT