//************************************************************************// // // // Copyright 2013 Bertram Kopf (bertram@ep1.rub.de) // // Julian Pychy (julian@ep1.rub.de) // // - Ruhr-Universität Bochum // // // // This file is part of Pawian. // // // // Pawian is free software: you can redistribute it and/or modify // // it under the terms of the GNU General Public License as published by // // the Free Software Foundation, either version 3 of the License, or // // (at your option) any later version. // // // // Pawian is distributed in the hope that it will be useful, // // but WITHOUT ANY WARRANTY; without even the implied warranty of // // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // // GNU General Public License for more details. // // // // You should have received a copy of the GNU General Public License // // along with Pawian. If not, see <http://www.gnu.org/licenses/>. // // // //************************************************************************// // AbsXdecAmp class definition file. -*- C++ -*- // Copyright 2012 Bertram Kopf #include <getopt.h> #include <fstream> #include <string> #include "PwaUtils/AbsXdecAmp.hh" #include "PwaUtils/AbsDecay.hh" #include "PwaUtils/XdecAmpRegistry.hh" #include "PwaUtils/DynRegistry.hh" #include "qft++/relativistic-quantum-mechanics/Utils.hh" #include "ErrLogger/ErrLogger.hh" #include "Particle/Particle.hh" AbsXdecAmp::AbsXdecAmp(boost::shared_ptr<AbsDecay> theDec) : AbsParamHandler() , _decay(theDec) , _name(theDec->name()) ,_JPCPtr(theDec->motherJPC()) ,_absDyn(theDec->getDynamics()) ,_key("_"+theDec->fitParSuffix()) ,_wignerDKey(theDec->wignerDKey()) ,_daughter1IsStable(theDec->isDaughter1Stable()) ,_daughter2IsStable(theDec->isDaughter2Stable()) ,_enabledlamFsDaughter1(false) ,_enabledlamFsDaughter2(false) { initialize(); } AbsXdecAmp::~AbsXdecAmp() { } void AbsXdecAmp::initialize(){ _absDyn = DynRegistry::instance()->getDynamics(_decay); if(!_daughter1IsStable){ boost::shared_ptr<AbsDecay> decDaughter1=_decay->decDaughter1(); boost::shared_ptr<AbsDynamics> currentDyn=decDaughter1->getDynamics(); if (0!=currentDyn) decDaughter1->getDynamics()->addGrandMa(_decay); else{ Warning <<"no dynamics for\t" << decDaughter1->name() << endmsg; } _decAmpDaughter1=XdecAmpRegistry::instance()->getXdecAmp(decDaughter1); } if(!_daughter2IsStable){ boost::shared_ptr<AbsDecay> decDaughter2=_decay->decDaughter2(); // decDaughter2->getDynamics()->addGrandMa(_decay); boost::shared_ptr<AbsDynamics> currentDyn=decDaughter2->getDynamics(); if (0!=currentDyn) decDaughter2->getDynamics()->addGrandMa(_decay); else{ Warning <<"no dynamics for\t" << decDaughter2->name() << endmsg; } _decAmpDaughter2=XdecAmpRegistry::instance()->getXdecAmp(decDaughter2); } _Jdaughter1=(Spin) _decay->daughter1Part()->J(); _Jdaughter2=(Spin) _decay->daughter2Part()->J(); if( _daughter1IsStable && _Jdaughter1>0) _enabledlamFsDaughter1=true; if( _daughter2IsStable && _Jdaughter2>0) _enabledlamFsDaughter2=true; } complex<double> AbsXdecAmp::daughterAmp(Spin lam1, Spin lam2, EvtData* theData, Spin lamFs){ complex<double> result(1.,0.); if(!_daughter1IsStable) result *= _decAmpDaughter1->XdecAmp(lam1, theData, lamFs, this); if(!_daughter2IsStable) result *= _decAmpDaughter2->XdecAmp(lam2, theData, lamFs, this); return result; } void AbsXdecAmp::cacheAmplitudes(){ _cacheAmps=true; _absDyn->cacheAmplitudes(); if(!_daughter1IsStable) _decAmpDaughter1->cacheAmplitudes(); if(!_daughter2IsStable) _decAmpDaughter2->cacheAmplitudes(); }