Laura++
3.6.0
A maximum likelihood fitting package for performing Dalitz-plot analysis.
|
Go to the documentation of this file.
37 const Int_t resPairAmpInt,
48 const Double_t b1Val = 24.49;
49 const Double_t b2Val = 0.0;
50 const Double_t aVal = 2.5;
51 const Double_t m0Val = 3.3;
55 TString b1Name( parNameBase );
64 TString b2Name( parNameBase );
73 TString aName( parNameBase );
82 TString m0Name( parNameBase );
100 Double_t resSpin = this-> getSpin();
101 if ( resSpin != 0 ) {
102 std::cerr << "WARNING in LauKappaRes::initialise : Resonance spin is " << resSpin << "."
104 std::cerr << " : Kappa amplitude is only for scalers, resetting spin to 0."
115 if ( resPairAmpInt < 1 || resPairAmpInt > 3 ) {
116 std::cerr << "WARNING in LauKappaRes::checkDaughterTypes : resPairAmpInt = " << resPairAmpInt
117 << " is out of the range [1,2,3]." << std::endl;
123 if ( ! ( nameDaug1.Contains( "pi", TString::kIgnoreCase ) &&
124 nameDaug2.Contains( "k", TString::kIgnoreCase ) ) ) {
125 if ( ! ( nameDaug2.Contains( "pi", TString::kIgnoreCase ) &&
126 nameDaug1.Contains( "k", TString::kIgnoreCase ) ) ) {
127 std::cerr << "ERROR in LauKappaRes::checkDaughterTypes : Kappa model is using daughters \""
128 << nameDaug1 << "\" and \"" << nameDaug2
129 << "\" that are not a kaon and a pion." << std::endl;
144 Double_t s = mass * mass;
147 rho = TMath::Sqrt( 1.0 - mSumSq_ / s );
151 const Double_t m0Sq = m0Val * m0Val;
157 Double_t f = b2Val * s + b1Val;
158 Double_t numerator = s - sAdler_;
159 Double_t denom = m0Sq - sAdler_;
160 Double_t gamma( 0.0 );
161 if ( TMath::Abs( denom ) > 1e-10 && TMath::Abs( aVal ) > 1e-10 ) {
163 gamma = rho * ( numerator / denom ) * f * TMath::Exp( -( s - m0Sq ) / aVal );
170 Double_t dMSq = m0Sq - s;
171 Double_t widthTerm = gamma * m0Val;
174 Double_t denomFactor = dMSq * dMSq + widthTerm * widthTerm;
176 Double_t invDenomFactor = 0.0;
177 if ( denomFactor > 1e-10 ) {
178 invDenomFactor = 1.0 / denomFactor;
181 resAmplitude. rescale( spinTerm * invDenomFactor );
212 if ( name == "b1" ) {
214 std::cout << "INFO in LauKappaRes::setResonanceParameter : Setting parameter b1 = "
216 } else if ( name == "b2" ) {
218 std::cout << "INFO in LauKappaRes::setResonanceParameter : Setting parameter b2 = "
220 } else if ( name == "A" ) {
222 std::cout << "INFO in LauKappaRes::setResonanceParameter : Setting parameter A = "
224 } else if ( name == "m0" ) {
226 std::cout << "INFO in LauKappaRes::setResonanceParameter : Setting parameter m0 = "
229 std::cerr << "WARNING in LauKappaRes::setResonanceParameter: Parameter name not reconised. No parameter changes made."
236 if ( name == "b1" ) {
241 std::cerr << "WARNING in LauKappaRes::floatResonanceParameter: Parameter already floating. No parameter changes made."
244 } else if ( name == "b2" ) {
249 std::cerr << "WARNING in LauKappaRes::floatResonanceParameter: Parameter already floating. No parameter changes made."
252 } else if ( name == "A" ) {
257 std::cerr << "WARNING in LauKappaRes::floatResonanceParameter: Parameter already floating. No parameter changes made."
260 } else if ( name == "m0" ) {
265 std::cerr << "WARNING in LauKappaRes::floatResonanceParameter: Parameter already floating. No parameter changes made."
269 std::cerr << "WARNING in LauKappaRes::fixResonanceParameter: Parameter name not reconised. No parameter changes made."
276 if ( name == "b1" ) {
278 } else if ( name == "b2" ) {
280 } else if ( name == "A" ) {
282 } else if ( name == "m0" ) {
285 std::cerr << "WARNING in LauKappaRes::getResonanceParameter: Parameter name not reconised."
virtual void floatResonanceParameter(const TString &name) Allow the various parameters to float in the fit.
File containing declaration of LauResonanceInfo class.
const Double_t mPiSq Square of pi+- mass.
virtual LauComplex resAmp(Double_t mass, Double_t spinTerm) Complex resonant amplitude.
const TString & getSanitisedName() const Get the name of the resonance.
Class for defining the fit parameter objects.
Double_t getAValue() const Get the A parameter value.
Double_t value() const The value of the parameter.
Bool_t fixB1Value() const Fix the b1 parameter value.
void setM0Value(const Double_t m0) Set the m0 parameter.
std::vector< LauParameter * > & getParameters() Access the list of floating parameters.
Double_t getB2Value() const Get the b2 parameter value.
void setAValue(const Double_t A) Set the A parameter.
Bool_t fixAValue() const Fix the A parameter value.
Bool_t fixB2Value() const Fix the b2 parameter value.
LauParameter * getExtraParameter(const TString &parName) Retrieve an extra parameter of the resonance.
void setB2Value(const Double_t b2) Set the b2 parameter.
virtual void initialise() Initialise the model.
virtual LauParameter * getResonanceParameter(const TString &name) Access the given resonance parameter.
Int_t getSpin() const Get the spin of the resonance.
Bool_t secondStage() const Check whether the parameter should be floated only in the second stage of a two stage fit.
Class for defining a complex number.
void changeResonance(const Double_t newMass, const Double_t newWidth, const Int_t newSpin) Allow the mass, width and spin of the resonance to be changed.
void addFloatingParameter(LauParameter *param) Add parameter to the list of floating parameters.
Namespace to contain various constants.
Int_t getPairInt() const Get the integer to identify which DP axis the resonance belongs to.
void rescale(Double_t scaleVal) Scale this by a factor.
File containing declaration of LauKappaRes class.
LauParameter * m0_ Factor from BES data.
LauParameter * b1_ Factor from BES data.
const Double_t mKSq Square of K+- mass.
void checkDaughterTypes() const Check that Kappa daughters are K and pi.
void setB1Value(const Double_t b1) Set the b1 parameter.
void addExtraParameter(LauParameter *param, const Bool_t independentPar=kFALSE) Add an extra parameter of the resonance.
const Double_t sAdler_ Defined as mK*mK - 0.5*mPi*mPi.
Bool_t fixed() const Check whether the parameter is fixed or floated.
Double_t getB1Value() const Get the b1 parameter value.
LauParameter() Default constructor.
LauParameter * b2_ Factor from BES data.
Class for defining the properties of a resonant particle.
File containing LauConstants namespace.
const TString & name() const The parameter name.
virtual ~LauKappaRes() Destructor.
Double_t getM0Value() const Get the m0 parameter value.
const Double_t mK Mass of K+- (GeV/c^2)
void clearFloatingParameters() Clear list of floating parameters.
Abstract class for defining type for resonance amplitude models (Breit-Wigner, Flatte etc....
virtual const std::vector< LauParameter * > & getFloatingParameters() Retrieve the resonance parameters, e.g. so that they can be loaded into a fit.
LauKappaRes(LauResonanceInfo *resInfo, const Int_t resPairAmpInt, const LauDaughters *daughters) Constructor.
Bool_t fixM0Value() const Fix the m0 parameter value.
Double_t genValue() const The value generated for the parameter.
const Double_t mSumSq_ Square of (mK + mPi)
const Double_t mPi Mass of pi+- (GeV/c^2)
LauParameter * a_ Factor from BES data.
Class that defines the particular 3-body decay under study.
TString getNameDaug1() const Get the name of the first daughter of the resonance.
TString getNameDaug2() const Get the name of the second daughter of the resonance.
Double_t initValue() const The initial value of the parameter.
virtual void setResonanceParameter(const TString &name, const Double_t value) Set value of the various parameters.
|