Skip to content
Snippets Groups Projects
BarrierFactor.cc 4.49 KiB
Newer Older
Julian Pychy's avatar
Julian Pychy committed
//************************************************************************//
//                                                                        //
//  Copyright 2014 Bertram Kopf (bertram@ep1.rub.de)                      //
//                 Julian Pychy (julian@ep1.rub.de)                       //
Julian Pychy's avatar
Julian Pychy committed
//                                                                        //
//  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/>.       //
//                                                                        //
//************************************************************************//

#include <cmath>
#include "PwaDynamics/BarrierFactor.hh"
Julian Pychy's avatar
Julian Pychy committed
#include "ErrLogger/ErrLogger.hh"

const double BarrierFactor::qRDefault = 0.1973; // GeV

BarrierFactor::BarrierFactor(int l, std::complex<double> q0, double qR) :
Julian Pychy's avatar
Julian Pychy committed
   _l(l),
   _qR(qR),
   _q0(q0)
{
   _B0 = BlattWeisskopf(_q0);
}



std::complex<double> BarrierFactor::BlattWeisskopf(std::complex<double> q){
   std::complex<double> z0(std::norm(q)/std::norm(_qR));
   return BlattWeisskopf(_l, z0);
//   return BlattWeisskopf(_l, q*q/_qR/_qR);
std::complex<double> BarrierFactor::BlattWeisskopf(int l, std::complex<double> q, double qR){
   std::complex<double> z(std::norm(q)/std::norm(qR));
   return BlattWeisskopf(l, z);
//   return BlattWeisskopf(l, q*q/qR/qR);
std::complex<double> BarrierFactor::BlattWeisskopfTensor(int l, std::complex<double> q, double qR){
   std::complex<double> z(std::norm(q)/std::norm(qR));
   return BlattWeisskopf(l, z)/pow(q,l);
//   return BlattWeisskopf(l, q*q/qR/qR)/pow(q,l);
std::complex<double> BarrierFactor::BlattWeisskopf(int l, std::complex<double> z){
Julian Pychy's avatar
Julian Pychy committed

   if(0==l){
      return 1.0;
   }
   else if(1==l){
      return std::sqrt(2.*z / (z+1.));
   }
   else if(2==l){
      return sqrt(13.*z*z / (z*z + 3.*z + 9.));
   }
   else if(3==l){
      return sqrt(277.*z*z*z / (z*z*z + 6.*z*z + 45.*z + 225.));
   }
   else if(4==l){
      return sqrt(12746.*z*z*z*z / 
		  (z*z*z*z + 10.*z*z*z + 135.*z*z + 1575.*z + 11025.));
   }
   else if(5==l){
      return sqrt(998881.*z*z*z*z*z / 
		  (z*z*z*z*z + 15.*z*z*z*z + 315.*z*z*z + 
		   6300.*z*z + 99225.*z + 893025.));
   }
   else if(6==l){
Julian Pychy's avatar
Julian Pychy committed
      return sqrt(118394977.*z*z*z*z*z*z / 
		  (z*z*z*z*z*z + 21.*z*z*z*z*z + 630.*z*z*z*z + 18900.*z*z*z +
		   496125.*z*z + 9823275.*z + 108056025.));
   }
   else if(7==l){
      return sqrt(19727003738.*z*z*z*z*z*z*z /
		  (z*z*z*z*z*z*z + 28.*z*z*z*z*z*z + 1134.*z*z*z*z*z + 47250.*z*z*z*z +
		   1819125.*z*z*z + 58939650.*z*z + 1404728325.*z + 18261468225.));
   }
   else if(8>=l){  //attention work-around for l>=9
      return sqrt(4392846440677.*z*z*z*z*z*z*z*z /
		  (z*z*z*z*z*z*z*z + 36.*z*z*z*z*z*z*z + 1890.*z*z*z*z*z*z +
		   103950.*z*z*z*z*z + 5457375.*z*z*z*z + 255405150.*z*z*z +
		   9833098275.*z*z + 273922023375.*z + 4108830350625.));
   }
Julian Pychy's avatar
Julian Pychy committed
   else{
      Alert << "Cannot compute BlattWeisskopf factor for l=" << l << endmsg;
   }
   return 0;
}



std::complex<double> BarrierFactor::BlattWeisskopfRatio(std::complex<double> q){
Julian Pychy's avatar
Julian Pychy committed
   return BlattWeisskopf(q) / _B0;
}



std::complex<double> BarrierFactor::BlattWeisskopfRatio(int l, std::complex<double> q, std::complex<double> q0, double qR){
Julian Pychy's avatar
Julian Pychy committed
   return BlattWeisskopf(l, q, qR) / BlattWeisskopf(l, q0, qR);
}

std::complex<double> BarrierFactor::BlattWeisskopfTensorRatio(int l, std::complex<double> q, std::complex<double> q0, double qR){
   return BlattWeisskopfTensor(l, q, qR) / BlattWeisskopfTensor(l, q0, qR);
}