Skip to content
Snippets Groups Projects
AbsXdecAmp.hh 1.45 KiB
Newer Older

#include <iostream>
#include <vector>
#include <complex>
#include <map>
#include <string>
#include <boost/shared_ptr.hpp>

#include "PwaUtils/EvtDataBaseListNew.hh"
#include "PwaUtils/FitParamsBaseNew.hh"

class AbsXdecAmp {

public:
Bertram Kopf's avatar
Bertram Kopf committed
  AbsXdecAmp(const std::string& name, const std::vector<std::string>& hypVec, Spin spinX=0, int parity=1);
  AbsXdecAmp(const std::string& name);
  virtual complex<double> XdecAmp(Spin lamX, EvtDataNew* theData)=0;
  virtual void getDefaultParams(fitParamsNew& fitVal, fitParamsNew& fitErr)=0;
  virtual void print(std::ostream& os) const=0;
  const std::string name() const {return _name;}
  const Spin  spinX() const {return _J_X;}
Bertram Kopf's avatar
Bertram Kopf committed
  const int  parity() const {return _parity;}
  virtual bool checkRecalculation(fitParamsNew& theParamVal);
  virtual void cacheAmplitudes(){_cacheAmps=true;}
  virtual void updateFitParams(fitParamsNew& theParamVal){return;}
  const std::string _name;
  const std::vector<std::string> _hypVec;
Bertram Kopf's avatar
Bertram Kopf committed
  Spin _J_X;
  int _parity; 
  std::map< boost::shared_ptr<const JPCLS>, double, pawian::Collection::SharedPtrLess > _currentParamMags;
  std::map< boost::shared_ptr<const JPCLS>, double, pawian::Collection::SharedPtrLess > _currentParamPhis;
  double _currentXMass;
  double _currentXWidth;
  double _currentgFactorPhiPhi;
  double _currentgFactorOmegaPhi;
  bool _recalculate;
  std::map<int, std::map<Spin, complex<double> > > _cachedAmpMap;