110448Snilay@cs.wisc.edu/* Copyright (c) 2012 Massachusetts Institute of Technology 210448Snilay@cs.wisc.edu * 310448Snilay@cs.wisc.edu * Permission is hereby granted, free of charge, to any person obtaining a copy 410448Snilay@cs.wisc.edu * of this software and associated documentation files (the "Software"), to deal 510448Snilay@cs.wisc.edu * in the Software without restriction, including without limitation the rights 610448Snilay@cs.wisc.edu * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 710448Snilay@cs.wisc.edu * copies of the Software, and to permit persons to whom the Software is 810448Snilay@cs.wisc.edu * furnished to do so, subject to the following conditions: 910448Snilay@cs.wisc.edu * 1010448Snilay@cs.wisc.edu * The above copyright notice and this permission notice shall be included in 1110448Snilay@cs.wisc.edu * all copies or substantial portions of the Software. 1210448Snilay@cs.wisc.edu * 1310448Snilay@cs.wisc.edu * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1410448Snilay@cs.wisc.edu * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 1510448Snilay@cs.wisc.edu * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 1610448Snilay@cs.wisc.edu * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 1710448Snilay@cs.wisc.edu * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 1810448Snilay@cs.wisc.edu * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 1910448Snilay@cs.wisc.edu * THE SOFTWARE. 2010448Snilay@cs.wisc.edu */ 2110448Snilay@cs.wisc.edu 2210447Snilay@cs.wisc.edu 2310447Snilay@cs.wisc.edu#include "model/optical_graph/OpticalFilter.h" 2410447Snilay@cs.wisc.edu 2510447Snilay@cs.wisc.edunamespace DSENT 2610447Snilay@cs.wisc.edu{ 2710447Snilay@cs.wisc.edu OpticalFilter::OpticalFilter(const String& instance_name_, OpticalModel* model_, const WavelengthGroup& wavelengths_, bool drop_all_, const WavelengthGroup& drop_wavelengths_) 2810447Snilay@cs.wisc.edu : OpticalNode(OpticalNode::FILTER, instance_name_, model_, wavelengths_), m_drop_all_(drop_all_), m_drop_wavelengths_(drop_wavelengths_) 2910447Snilay@cs.wisc.edu { 3010447Snilay@cs.wisc.edu m_drop_loss_ = 0.0; 3110447Snilay@cs.wisc.edu m_drop_port_ = NULL; 3210447Snilay@cs.wisc.edu } 3310447Snilay@cs.wisc.edu 3410447Snilay@cs.wisc.edu OpticalFilter::~OpticalFilter() 3510447Snilay@cs.wisc.edu { 3610447Snilay@cs.wisc.edu 3710447Snilay@cs.wisc.edu } 3810447Snilay@cs.wisc.edu 3910447Snilay@cs.wisc.edu bool OpticalFilter::getDropAll() const 4010447Snilay@cs.wisc.edu { 4110447Snilay@cs.wisc.edu return m_drop_all_; 4210447Snilay@cs.wisc.edu } 4310447Snilay@cs.wisc.edu 4410447Snilay@cs.wisc.edu WavelengthGroup OpticalFilter::getDropWavelengths() const 4510447Snilay@cs.wisc.edu { 4610447Snilay@cs.wisc.edu return m_drop_wavelengths_; 4710447Snilay@cs.wisc.edu } 4810447Snilay@cs.wisc.edu 4910447Snilay@cs.wisc.edu void OpticalFilter::setDropLoss(double drop_loss_) 5010447Snilay@cs.wisc.edu { 5110447Snilay@cs.wisc.edu m_drop_loss_ = drop_loss_; 5210447Snilay@cs.wisc.edu return; 5310447Snilay@cs.wisc.edu } 5410447Snilay@cs.wisc.edu 5510447Snilay@cs.wisc.edu double OpticalFilter::getDropLoss() const 5610447Snilay@cs.wisc.edu { 5710447Snilay@cs.wisc.edu return m_drop_loss_; 5810447Snilay@cs.wisc.edu } 5910447Snilay@cs.wisc.edu 6010447Snilay@cs.wisc.edu void OpticalFilter::setDropPort(OpticalNode* drop_port_) 6110447Snilay@cs.wisc.edu { 6210447Snilay@cs.wisc.edu m_drop_port_ = drop_port_; 6310447Snilay@cs.wisc.edu } 6410447Snilay@cs.wisc.edu 6510447Snilay@cs.wisc.edu OpticalNode* OpticalFilter::getDropPort() 6610447Snilay@cs.wisc.edu { 6710447Snilay@cs.wisc.edu return m_drop_port_; 6810447Snilay@cs.wisc.edu } 6910447Snilay@cs.wisc.edu 7010447Snilay@cs.wisc.edu bool OpticalFilter::isDropped(const WavelengthGroup& wavelengths_) const 7110447Snilay@cs.wisc.edu { 7210447Snilay@cs.wisc.edu // Check that the lower limits are within bounds 7310447Snilay@cs.wisc.edu bool lower_match = (wavelengths_.first >= getDropWavelengths().first); 7410447Snilay@cs.wisc.edu // Check that the upper limits are within bounds 7510447Snilay@cs.wisc.edu bool upper_match = (wavelengths_.second <= getDropWavelengths().second); 7610447Snilay@cs.wisc.edu // Assert that there are no misalignments 7710447Snilay@cs.wisc.edu ASSERT(lower_match == upper_match, "[Error] " + getInstanceName() + 7810447Snilay@cs.wisc.edu " -> Wavelength group misalignment!" + 7910447Snilay@cs.wisc.edu " InWavelength" + toString(wavelengths_) + 8010447Snilay@cs.wisc.edu ", DropWavelength" + toString(getDropWavelengths())); 8110447Snilay@cs.wisc.edu // Both upper and lower bounds must match 8210447Snilay@cs.wisc.edu return (upper_match && lower_match); 8310447Snilay@cs.wisc.edu } 8410447Snilay@cs.wisc.edu} // namespace DSENT 8510447Snilay@cs.wisc.edu 8610447Snilay@cs.wisc.edu 87