Something went wrong on our end
-
Bertram Kopf authoredabbba54d
AbsDecayList.cc 2.23 KiB
// AbsDecayList class definition file. -*- C++ -*-
// Copyright 2012 Bertram Kopf
#include <getopt.h>
#include <fstream>
#include <iostream>
#include <boost/algorithm/string.hpp>
#include "PwaUtils/AbsDecayList.hh"
#include "PwaUtils/AbsDecay.hh"
#include "qft++/relativistic-quantum-mechanics/Utils.hh"
#include "ErrLogger/ErrLogger.hh"
#include "Particle/Particle.hh"
AbsDecayList::AbsDecayList(){
}
AbsDecayList::~AbsDecayList(){
}
void AbsDecayList::addDecay(boost::shared_ptr<AbsDecay> theIsoDec){
// const std::string key = theIsoDec->motherPart()->name();
// std::map<const std::string, boost::shared_ptr<AbsDecay> >::iterator it;
// it=_absDecList.find(key);
// if (it != _absDecList.end()){
_absDecList.push_back(theIsoDec);
// }
// else{
// Warning << "decay of the particle " << key << " already exists\n"
// << "new decay cannot be added!!!" << endmsg;
// }
}
boost::shared_ptr<AbsDecay> AbsDecayList::decay(Particle* mother){
boost::shared_ptr<AbsDecay> result;
const std::string key = mother->name();
std::vector<boost::shared_ptr<AbsDecay> >::iterator it;
for (it=_absDecList.begin(); it!=_absDecList.end(); ++it){
if (key==(*it)->motherPart()->name()){
result=(*it);
break;
}
}
return result;
}
boost::shared_ptr<AbsDecay> AbsDecayList::decay(const std::string& name){
boost::shared_ptr<AbsDecay> result;
std::vector<boost::shared_ptr<AbsDecay> >::iterator it;
for (it=_absDecList.begin(); it!=_absDecList.end(); ++it){
if (name==(*it)->name()){
result=(*it);
break;
}
}
return result;
}
void AbsDecayList::replaceSuffix(const std::string& oldPart, const std::string& newPart){
std::vector<boost::shared_ptr<AbsDecay> >::iterator it;
for (it= _absDecList.begin(); it!=_absDecList.end(); ++it){
std::string theSuffix= (*it)->fitParSuffix();
boost::replace_all(theSuffix, oldPart, newPart);
(*it)->setFitParSuffix(theSuffix);
}
}
void AbsDecayList::replaceMassKey(const std::string& oldPart, const std::string& newPart){
std::vector<boost::shared_ptr<AbsDecay> >::iterator it;
for (it= _absDecList.begin(); it!=_absDecList.end(); ++it){
if(oldPart== (*it)->massParKey()){
(*it)->setMassParKey(newPart);
}
}
}