SWSRLink.cc revision 10447
110447Snilay@cs.wisc.edu#include "model/optical/SWSRLink.h" 210447Snilay@cs.wisc.edu 310447Snilay@cs.wisc.edu#include "model/ModelGen.h" 410447Snilay@cs.wisc.edu#include "model/PortInfo.h" 510447Snilay@cs.wisc.edu#include "model/TransitionInfo.h" 610447Snilay@cs.wisc.edu#include "model/EventInfo.h" 710447Snilay@cs.wisc.edu#include "model/optical_graph/OpticalGraph.h" 810447Snilay@cs.wisc.edu#include "model/optical_graph/OpticalWaveguide.h" 910447Snilay@cs.wisc.edu#include "model/optical/RingModulator.h" 1010447Snilay@cs.wisc.edu#include "model/optical/RingFilter.h" 1110447Snilay@cs.wisc.edu#include "model/optical/RingDetector.h" 1210447Snilay@cs.wisc.edu#include "model/optical/LaserSource.h" 1310447Snilay@cs.wisc.edu#include "model/optical/ThrottledLaserSource.h" 1410447Snilay@cs.wisc.edu 1510447Snilay@cs.wisc.edunamespace DSENT 1610447Snilay@cs.wisc.edu{ 1710447Snilay@cs.wisc.edu SWSRLink::SWSRLink(const String& instance_name_, const TechModel* tech_model_) 1810447Snilay@cs.wisc.edu : OpticalModel(instance_name_, tech_model_) 1910447Snilay@cs.wisc.edu { 2010447Snilay@cs.wisc.edu initParameters(); 2110447Snilay@cs.wisc.edu initProperties(); 2210447Snilay@cs.wisc.edu } 2310447Snilay@cs.wisc.edu 2410447Snilay@cs.wisc.edu SWSRLink::~SWSRLink() 2510447Snilay@cs.wisc.edu {} 2610447Snilay@cs.wisc.edu 2710447Snilay@cs.wisc.edu void SWSRLink::initParameters() 2810447Snilay@cs.wisc.edu { 2910447Snilay@cs.wisc.edu addParameterName("NumberBits"); 3010447Snilay@cs.wisc.edu addParameterName("CoreDataRate"); 3110447Snilay@cs.wisc.edu addParameterName("LinkDataRate"); 3210447Snilay@cs.wisc.edu 3310447Snilay@cs.wisc.edu addParameterName("LaserType"); 3410447Snilay@cs.wisc.edu addParameterName("RingTuningMethod"); 3510447Snilay@cs.wisc.edu addParameterName("OptimizeLoss", "TRUE"); 3610447Snilay@cs.wisc.edu 3710447Snilay@cs.wisc.edu return; 3810447Snilay@cs.wisc.edu } 3910447Snilay@cs.wisc.edu 4010447Snilay@cs.wisc.edu void SWSRLink::initProperties() 4110447Snilay@cs.wisc.edu { 4210447Snilay@cs.wisc.edu addPropertyName("Length"); 4310447Snilay@cs.wisc.edu addPropertyName("OptUtil", 0.5); // default to 50% utilization (a new word 50% of the time) 4410447Snilay@cs.wisc.edu addPropertyName("ExtinctionRatio", 6); // default properties 4510447Snilay@cs.wisc.edu addPropertyName("InsertionLoss", 2); // default properties 4610447Snilay@cs.wisc.edu return; 4710447Snilay@cs.wisc.edu } 4810447Snilay@cs.wisc.edu 4910447Snilay@cs.wisc.edu void SWSRLink::constructModel() 5010447Snilay@cs.wisc.edu { 5110447Snilay@cs.wisc.edu // Get parameters 5210447Snilay@cs.wisc.edu unsigned int number_bits = getParameter("NumberBits"); 5310447Snilay@cs.wisc.edu double core_data_rate = getParameter("CoreDataRate"); 5410447Snilay@cs.wisc.edu double link_data_rate = getParameter("LinkDataRate"); 5510447Snilay@cs.wisc.edu 5610447Snilay@cs.wisc.edu // Get directly propagated parameters 5710447Snilay@cs.wisc.edu const String& ring_tuning_method = getParameter("RingTuningMethod"); 5810447Snilay@cs.wisc.edu 5910447Snilay@cs.wisc.edu // Calculate number of wavelengths needed 6010447Snilay@cs.wisc.edu unsigned int number_wavelengths = (unsigned int)((double) number_bits * core_data_rate / link_data_rate); 6110447Snilay@cs.wisc.edu 6210447Snilay@cs.wisc.edu // Set some generated properties 6310447Snilay@cs.wisc.edu getGenProperties()->set("NumberWavelengths", number_wavelengths); 6410447Snilay@cs.wisc.edu 6510447Snilay@cs.wisc.edu // Create electrical ports 6610447Snilay@cs.wisc.edu createInputPort("LinkCK"); 6710447Snilay@cs.wisc.edu createInputPort("In", makeNetIndex(0, number_bits-1)); 6810447Snilay@cs.wisc.edu createOutputPort("Out", makeNetIndex(0, number_bits-1)); 6910447Snilay@cs.wisc.edu 7010447Snilay@cs.wisc.edu // Create Waveguides 7110447Snilay@cs.wisc.edu // Temporarily assume its all on one waveguide 7210447Snilay@cs.wisc.edu createWaveguide("LaserToMod", makeWavelengthGroup(0, number_wavelengths-1)); 7310447Snilay@cs.wisc.edu createWaveguide("ModToDetector", makeWavelengthGroup(0, number_wavelengths-1)); 7410447Snilay@cs.wisc.edu 7510447Snilay@cs.wisc.edu // Add area results 7610447Snilay@cs.wisc.edu addAreaResult(new Result("Photonic")); 7710447Snilay@cs.wisc.edu createElectricalResults(); 7810447Snilay@cs.wisc.edu // Setup idle event 7910447Snilay@cs.wisc.edu getEventInfo("Idle")->setStaticTransitionInfos(); 8010447Snilay@cs.wisc.edu // Create a waveguide area result 8110447Snilay@cs.wisc.edu addAreaResult(new AtomicResult("Waveguide")); 8210447Snilay@cs.wisc.edu getAreaResult("Photonic")->addSubResult(getAreaResult("Waveguide"), "Waveguide", 1.0); 8310447Snilay@cs.wisc.edu // Add results 8410447Snilay@cs.wisc.edu addNddPowerResult(new Result("Laser")); 8510447Snilay@cs.wisc.edu addNddPowerResult(new Result("RingTuning")); 8610447Snilay@cs.wisc.edu // Add event result 8710447Snilay@cs.wisc.edu createElectricalEventResult("Send"); 8810447Snilay@cs.wisc.edu 8910447Snilay@cs.wisc.edu // Create Tx, Rx backends 9010447Snilay@cs.wisc.edu // Create Tx electrical backend 9110447Snilay@cs.wisc.edu ElectricalModel* tx_backend = (ElectricalModel*) ModelGen::createModel("OpticalLinkBackendTx", "OpticalLinkBackendTx", getTechModel()); 9210447Snilay@cs.wisc.edu tx_backend->setParameter("InBits", number_bits); 9310447Snilay@cs.wisc.edu tx_backend->setParameter("CoreDataRate", core_data_rate); 9410447Snilay@cs.wisc.edu tx_backend->setParameter("LinkDataRate", link_data_rate); 9510447Snilay@cs.wisc.edu tx_backend->setParameter("RingTuningMethod", ring_tuning_method); 9610447Snilay@cs.wisc.edu tx_backend->setParameter("BitDuplicate", "TRUE"); 9710447Snilay@cs.wisc.edu tx_backend->construct(); 9810447Snilay@cs.wisc.edu 9910447Snilay@cs.wisc.edu // Create Rx electrical backend 10010447Snilay@cs.wisc.edu ElectricalModel* rx_backend = (ElectricalModel*) ModelGen::createModel("OpticalLinkBackendRx", "OpticalLinkBackendRx", getTechModel()); 10110447Snilay@cs.wisc.edu rx_backend->setParameter("OutBits", number_bits); 10210447Snilay@cs.wisc.edu rx_backend->setParameter("CoreDataRate", core_data_rate); 10310447Snilay@cs.wisc.edu rx_backend->setParameter("LinkDataRate", link_data_rate); 10410447Snilay@cs.wisc.edu rx_backend->setParameter("RingTuningMethod", ring_tuning_method); 10510447Snilay@cs.wisc.edu rx_backend->setParameter("BitDuplicate", "TRUE"); 10610447Snilay@cs.wisc.edu rx_backend->construct(); 10710447Snilay@cs.wisc.edu 10810447Snilay@cs.wisc.edu // Connect ports 10910447Snilay@cs.wisc.edu createNet("TxBackendToTx", makeNetIndex(0, number_wavelengths-1)); 11010447Snilay@cs.wisc.edu createNet("RxToRxBackend", makeNetIndex(0, number_wavelengths-1)); 11110447Snilay@cs.wisc.edu portConnect(tx_backend, "In", "In"); 11210447Snilay@cs.wisc.edu portConnect(tx_backend, "Out", "TxBackendToTx"); 11310447Snilay@cs.wisc.edu portConnect(tx_backend, "LinkCK", "LinkCK"); 11410447Snilay@cs.wisc.edu portConnect(rx_backend, "In", "RxToRxBackend"); 11510447Snilay@cs.wisc.edu portConnect(rx_backend, "Out", "Out"); 11610447Snilay@cs.wisc.edu portConnect(rx_backend, "LinkCK", "LinkCK"); 11710447Snilay@cs.wisc.edu 11810447Snilay@cs.wisc.edu // Add instances 11910447Snilay@cs.wisc.edu addSubInstances(tx_backend, 1.0); 12010447Snilay@cs.wisc.edu addSubInstances(rx_backend, 1.0); 12110447Snilay@cs.wisc.edu 12210447Snilay@cs.wisc.edu // Add electrical results 12310447Snilay@cs.wisc.edu addElectricalSubResults(tx_backend, 1.0); 12410447Snilay@cs.wisc.edu addElectricalSubResults(rx_backend, 1.0); 12510447Snilay@cs.wisc.edu 12610447Snilay@cs.wisc.edu // Add tuning power result 12710447Snilay@cs.wisc.edu getNddPowerResult("RingTuning")->addSubResult(tx_backend->getNddPowerResult("RingTuning"), "OpticalLinkBackendTx", 1.0); 12810447Snilay@cs.wisc.edu getNddPowerResult("RingTuning")->addSubResult(rx_backend->getNddPowerResult("RingTuning"), "OpticalLinkBackendRx", 1.0); 12910447Snilay@cs.wisc.edu 13010447Snilay@cs.wisc.edu // Add event results 13110447Snilay@cs.wisc.edu getEventInfo("Send")->setTransitionInfo("LinkCK", TransitionInfo(0.0, (double) link_data_rate / (core_data_rate * 2.0), 0.0)); 13210447Snilay@cs.wisc.edu 13310447Snilay@cs.wisc.edu getEventResult("Send")->addSubResult(tx_backend->getEventResult("ProcessBits"), "OpticalLinkBackendTx", 1.0); 13410447Snilay@cs.wisc.edu getEventResult("Send")->addSubResult(rx_backend->getEventResult("ProcessBits"), "OpticalLinkBackendRx", 1.0); 13510447Snilay@cs.wisc.edu 13610447Snilay@cs.wisc.edu buildLaser(); 13710447Snilay@cs.wisc.edu buildModulator(); 13810447Snilay@cs.wisc.edu buildDetector(); 13910447Snilay@cs.wisc.edu 14010447Snilay@cs.wisc.edu return; 14110447Snilay@cs.wisc.edu } 14210447Snilay@cs.wisc.edu 14310447Snilay@cs.wisc.edu void SWSRLink::updateModel() 14410447Snilay@cs.wisc.edu { 14510447Snilay@cs.wisc.edu // Get parameters 14610447Snilay@cs.wisc.edu double link_data_rate = getParameter("LinkDataRate"); 14710447Snilay@cs.wisc.edu 14810447Snilay@cs.wisc.edu // Get properties 14910447Snilay@cs.wisc.edu double length = getProperty("Length"); 15010447Snilay@cs.wisc.edu const String& extinction_ratio = getProperty("ExtinctionRatio"); 15110447Snilay@cs.wisc.edu const String& insertion_loss = getProperty("InsertionLoss"); 15210447Snilay@cs.wisc.edu const double opt_util = getProperty("OptUtil"); 15310447Snilay@cs.wisc.edu 15410447Snilay@cs.wisc.edu // Calculate loss for waveguide 15510447Snilay@cs.wisc.edu double waveguide_loss = getTechModel()->get("Waveguide->LossPerMeter").toDouble() * length; 15610447Snilay@cs.wisc.edu // Set loss of the waveguide 15710447Snilay@cs.wisc.edu getWaveguide("ModToDetector")->setLoss(waveguide_loss); 15810447Snilay@cs.wisc.edu // Calculate waveguide area 15910447Snilay@cs.wisc.edu double waveguide_area = length * getTechModel()->get("Waveguide->Pitch").toDouble(); 16010447Snilay@cs.wisc.edu getAreaResult("Waveguide")->setValue(waveguide_area); 16110447Snilay@cs.wisc.edu 16210447Snilay@cs.wisc.edu // Update the laser 16310447Snilay@cs.wisc.edu Model* laser = getSubInstance("Laser"); 16410447Snilay@cs.wisc.edu laser->setProperty("LaserEventTime", 1.0 / link_data_rate); 16510447Snilay@cs.wisc.edu laser->setProperty("OptUtil", opt_util); 16610447Snilay@cs.wisc.edu laser->update(); 16710447Snilay@cs.wisc.edu 16810447Snilay@cs.wisc.edu // Update the modulator 16910447Snilay@cs.wisc.edu Model* modulator = getSubInstance("Modulator"); 17010447Snilay@cs.wisc.edu modulator->setProperty("ExtinctionRatio", extinction_ratio); 17110447Snilay@cs.wisc.edu modulator->setProperty("InsertionLoss", insertion_loss); 17210447Snilay@cs.wisc.edu modulator->update(); 17310447Snilay@cs.wisc.edu 17410447Snilay@cs.wisc.edu Model* detector = getSubInstance("Detector"); 17510447Snilay@cs.wisc.edu detector->update(); 17610447Snilay@cs.wisc.edu 17710447Snilay@cs.wisc.edu Model* tx_backend = getSubInstance("OpticalLinkBackendTx"); 17810447Snilay@cs.wisc.edu tx_backend->update(); 17910447Snilay@cs.wisc.edu 18010447Snilay@cs.wisc.edu Model* rx_backend = getSubInstance("OpticalLinkBackendRx"); 18110447Snilay@cs.wisc.edu rx_backend->update(); 18210447Snilay@cs.wisc.edu 18310447Snilay@cs.wisc.edu return; 18410447Snilay@cs.wisc.edu } 18510447Snilay@cs.wisc.edu 18610447Snilay@cs.wisc.edu void SWSRLink::propagateTransitionInfo() 18710447Snilay@cs.wisc.edu { 18810447Snilay@cs.wisc.edu // Get parameters 18910447Snilay@cs.wisc.edu const String& laser_type = getParameter("LaserType"); 19010447Snilay@cs.wisc.edu 19110447Snilay@cs.wisc.edu // Propagate transition info to tx backend 19210447Snilay@cs.wisc.edu OpticalModel* tx_backend = (OpticalModel*) getSubInstance("OpticalLinkBackendTx"); 19310447Snilay@cs.wisc.edu propagatePortTransitionInfo(tx_backend, "In", "In"); 19410447Snilay@cs.wisc.edu propagatePortTransitionInfo(tx_backend, "LinkCK", "LinkCK"); 19510447Snilay@cs.wisc.edu tx_backend->use(); 19610447Snilay@cs.wisc.edu 19710447Snilay@cs.wisc.edu // Set transition info for the modulator 19810447Snilay@cs.wisc.edu OpticalModel* modulator = (OpticalModel*) getSubInstance("Modulator"); 19910447Snilay@cs.wisc.edu propagatePortTransitionInfo(modulator, "In", tx_backend, "Out"); 20010447Snilay@cs.wisc.edu modulator->use(); 20110447Snilay@cs.wisc.edu 20210447Snilay@cs.wisc.edu // Modulator out transition info 20310447Snilay@cs.wisc.edu const TransitionInfo& mod_out_transitions = modulator->getOpticalOutputPort("Out")->getTransitionInfo(); 20410447Snilay@cs.wisc.edu 20510447Snilay@cs.wisc.edu // Set transition info for the receiver 20610447Snilay@cs.wisc.edu OpticalModel* detector = (OpticalModel*) getSubInstance("Detector"); 20710447Snilay@cs.wisc.edu detector->getOpticalInputPort("In")->setTransitionInfo(mod_out_transitions); 20810447Snilay@cs.wisc.edu detector->use(); 20910447Snilay@cs.wisc.edu 21010447Snilay@cs.wisc.edu // Propagate transition info to tx backend 21110447Snilay@cs.wisc.edu OpticalModel* rx_backend = (OpticalModel*) getSubInstance("OpticalLinkBackendRx"); 21210447Snilay@cs.wisc.edu propagatePortTransitionInfo(rx_backend, "In", detector, "Out"); 21310447Snilay@cs.wisc.edu propagatePortTransitionInfo(rx_backend, "LinkCK", "LinkCK"); 21410447Snilay@cs.wisc.edu rx_backend->use(); 21510447Snilay@cs.wisc.edu 21610447Snilay@cs.wisc.edu // Propagate output transition info to output 21710447Snilay@cs.wisc.edu propagatePortTransitionInfo("Out", rx_backend, "Out"); 21810447Snilay@cs.wisc.edu 21910447Snilay@cs.wisc.edu // Set enable signals for the laser, if applicable 22010447Snilay@cs.wisc.edu if (laser_type == "Throttled") 22110447Snilay@cs.wisc.edu { 22210447Snilay@cs.wisc.edu // Figure out how many cycles the laser needs to be on 22310447Snilay@cs.wisc.edu double cycles = getInputPort("In")->getTransitionInfo().getFrequencyMultiplier(); 22410447Snilay@cs.wisc.edu 22510447Snilay@cs.wisc.edu OpticalModel* laser = (OpticalModel*) getSubInstance("Laser"); 22610447Snilay@cs.wisc.edu laser->getInputPort("LaserEnable")->setTransitionInfo(TransitionInfo(0.0, 1.0, cycles - 1.0)); 22710447Snilay@cs.wisc.edu laser->use(); 22810447Snilay@cs.wisc.edu } 22910447Snilay@cs.wisc.edu 23010447Snilay@cs.wisc.edu 23110447Snilay@cs.wisc.edu return; 23210447Snilay@cs.wisc.edu } 23310447Snilay@cs.wisc.edu 23410447Snilay@cs.wisc.edu void SWSRLink::buildLaser() 23510447Snilay@cs.wisc.edu { 23610447Snilay@cs.wisc.edu // Get parameters 23710447Snilay@cs.wisc.edu unsigned int number_wavelengths = getGenProperties()->get("NumberWavelengths"); 23810447Snilay@cs.wisc.edu const String& laser_type = getParameter("LaserType"); 23910447Snilay@cs.wisc.edu 24010447Snilay@cs.wisc.edu // Create laser 24110447Snilay@cs.wisc.edu OpticalModel* laser = NULL; 24210447Snilay@cs.wisc.edu if (laser_type == "Throttled") laser = new ThrottledLaserSource("Laser", getTechModel()); 24310447Snilay@cs.wisc.edu else if (laser_type == "Standard") laser = new LaserSource("Laser", getTechModel()); 24410447Snilay@cs.wisc.edu else ASSERT(false, "[Error] " + getInstanceName() + " -> Unknown laser type '" + laser_type + "'!"); 24510447Snilay@cs.wisc.edu 24610447Snilay@cs.wisc.edu laser->setParameter("OutStart", 0); 24710447Snilay@cs.wisc.edu laser->setParameter("OutEnd", number_wavelengths-1); 24810447Snilay@cs.wisc.edu laser->setParameter("MaxDetectors", 1); 24910447Snilay@cs.wisc.edu laser->setParameter("MinDetectors", 1); 25010447Snilay@cs.wisc.edu laser->construct(); 25110447Snilay@cs.wisc.edu 25210447Snilay@cs.wisc.edu addSubInstances(laser, 1.0); 25310447Snilay@cs.wisc.edu getAreaResult("Photonic")->addSubResult(laser->getAreaResult("Photonic"), "Laser", 1.0); 25410447Snilay@cs.wisc.edu // Connect laser output port 25510447Snilay@cs.wisc.edu opticalPortConnect(laser, "Out", "LaserToMod"); 25610447Snilay@cs.wisc.edu 25710447Snilay@cs.wisc.edu // Without laser gating, laser is pure NDD power 25810447Snilay@cs.wisc.edu if (laser_type == "Standard") getNddPowerResult("Laser")->addSubResult(laser->getNddPowerResult("Laser"), "Laser", 1.0); 25910447Snilay@cs.wisc.edu // With laser power gating, laser is an event 26010447Snilay@cs.wisc.edu else getEventResult("Send")->addSubResult(laser->getEventResult("Laser1"), "Laser", 1.0); 26110447Snilay@cs.wisc.edu 26210447Snilay@cs.wisc.edu return; 26310447Snilay@cs.wisc.edu } 26410447Snilay@cs.wisc.edu 26510447Snilay@cs.wisc.edu void SWSRLink::buildModulator() 26610447Snilay@cs.wisc.edu { 26710447Snilay@cs.wisc.edu // Get parameters 26810447Snilay@cs.wisc.edu double link_data_rate = getParameter("LinkDataRate"); 26910447Snilay@cs.wisc.edu const String& optimize_loss = getParameter("OptimizeLoss"); 27010447Snilay@cs.wisc.edu unsigned int number_wavelengths = getGenProperties()->get("NumberWavelengths"); 27110447Snilay@cs.wisc.edu 27210447Snilay@cs.wisc.edu // Create modulator 27310447Snilay@cs.wisc.edu RingModulator* modulator = new RingModulator("Modulator", getTechModel()); 27410447Snilay@cs.wisc.edu modulator->setParameter("DataRate", link_data_rate); 27510447Snilay@cs.wisc.edu modulator->setParameter("InStart", 0); 27610447Snilay@cs.wisc.edu modulator->setParameter("InEnd", number_wavelengths-1); 27710447Snilay@cs.wisc.edu modulator->setParameter("ModStart", 0); 27810447Snilay@cs.wisc.edu modulator->setParameter("ModEnd", number_wavelengths-1); 27910447Snilay@cs.wisc.edu modulator->setParameter("OptimizeLoss", optimize_loss); 28010447Snilay@cs.wisc.edu modulator->construct(); 28110447Snilay@cs.wisc.edu addSubInstances(modulator, 1.0); 28210447Snilay@cs.wisc.edu getAreaResult("Photonic")->addSubResult(modulator->getAreaResult("Photonic"), "Modulator", 1.0); 28310447Snilay@cs.wisc.edu addElectricalSubResults(modulator, 1.0); 28410447Snilay@cs.wisc.edu 28510447Snilay@cs.wisc.edu // Connect electrical port 28610447Snilay@cs.wisc.edu portConnect(modulator, "In", "TxBackendToTx"); 28710447Snilay@cs.wisc.edu // Connect modulator input, output port 28810447Snilay@cs.wisc.edu opticalPortConnect(modulator, "In", "LaserToMod"); 28910447Snilay@cs.wisc.edu opticalPortConnect(modulator, "Out", "ModToDetector"); 29010447Snilay@cs.wisc.edu 29110447Snilay@cs.wisc.edu // Add modulator energy event for send events 29210447Snilay@cs.wisc.edu getEventResult("Send")->addSubResult(modulator->getEventResult("Modulate"), "Modulator", 1.0); 29310447Snilay@cs.wisc.edu return; 29410447Snilay@cs.wisc.edu } 29510447Snilay@cs.wisc.edu 29610447Snilay@cs.wisc.edu void SWSRLink::buildDetector() 29710447Snilay@cs.wisc.edu { 29810447Snilay@cs.wisc.edu // Get parameters 29910447Snilay@cs.wisc.edu double link_data_rate = getParameter("LinkDataRate"); 30010447Snilay@cs.wisc.edu unsigned int number_wavelengths = getGenProperties()->get("NumberWavelengths"); 30110447Snilay@cs.wisc.edu 30210447Snilay@cs.wisc.edu // Create resonant ring detector 30310447Snilay@cs.wisc.edu RingDetector* detector = new RingDetector("Detector", getTechModel()); 30410447Snilay@cs.wisc.edu detector->setParameter("DataRate", link_data_rate); 30510447Snilay@cs.wisc.edu detector->setParameter("InStart", 0); 30610447Snilay@cs.wisc.edu detector->setParameter("InEnd", number_wavelengths-1); 30710447Snilay@cs.wisc.edu detector->setParameter("DetStart", 0); 30810447Snilay@cs.wisc.edu detector->setParameter("DetEnd", number_wavelengths-1); 30910447Snilay@cs.wisc.edu detector->setParameter("DropAll", "TRUE"); 31010447Snilay@cs.wisc.edu detector->setParameter("Topology", RingDetector::INTEGRATINGSENSEAMP); 31110447Snilay@cs.wisc.edu detector->construct(); 31210447Snilay@cs.wisc.edu addSubInstances(detector, 1.0); 31310447Snilay@cs.wisc.edu getAreaResult("Photonic")->addSubResult(detector->getAreaResult("Photonic"), "Detector", 1.0); 31410447Snilay@cs.wisc.edu addElectricalSubResults(detector, 1.0); 31510447Snilay@cs.wisc.edu 31610447Snilay@cs.wisc.edu // connect to electrical port 31710447Snilay@cs.wisc.edu portConnect(detector, "Out", "RxToRxBackend"); 31810447Snilay@cs.wisc.edu // connect optical input, output port 31910447Snilay@cs.wisc.edu opticalPortConnect(detector, "In", "ModToDetector"); 32010447Snilay@cs.wisc.edu 32110447Snilay@cs.wisc.edu // Add receiver energy 32210447Snilay@cs.wisc.edu getEventResult("Send")->addSubResult(detector->getEventResult("Receive"), "Detector", 1.0); 32310447Snilay@cs.wisc.edu 32410447Snilay@cs.wisc.edu return; 32510447Snilay@cs.wisc.edu } 32610447Snilay@cs.wisc.edu 32710447Snilay@cs.wisc.edu} // namespace DSENT 32810447Snilay@cs.wisc.edu 329