laura is hosted by Hepforge, IPPP Durham
Laura++  3.6.0
A maximum likelihood fitting package for performing Dalitz-plot analysis.
LauRescatteringRes.hh
Go to the documentation of this file.
1 /*
2 Copyright 2018 University of Warwick
3 
4 Licensed under the Apache License, Version 2.0 (the "License");
5 you may not use this file except in compliance with the License.
6 You may obtain a copy of the License at
7 
8  http://www.apache.org/licenses/LICENSE-2.0
9 
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an "AS IS" BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
15 */
16 
17 /*
18 Laura++ package authors:
19 John Back
20 Paul Harrison
21 Thomas Latham
22 */
23 
37 #ifndef LAU_RESCATTERING_RES
38 #define LAU_RESCATTERING_RES
39 
40 #include "LauAbsResonance.hh"
41 #include "LauComplex.hh"
42 
43 #include "TString.h"
44 
45 class LauKinematics;
46 class LauParameter;
47 
49 
50  public:
52 
60  const Int_t resPairAmpInt,
61  const LauDaughters* daughters );
62 
64  virtual ~LauRescatteringRes();
65 
67  virtual void initialise();
68 
70 
74  virtual LauComplex amplitude( const LauKinematics* kinematics );
75 
77 
82 
84 
88  virtual void setResonanceParameter( const TString& name, const Double_t value );
89 
91 
94  virtual void floatResonanceParameter( const TString& name );
95 
97 
101  virtual LauParameter* getResonanceParameter( const TString& name );
102 
104 
107  virtual const std::vector<LauParameter*>& getFloatingParameters();
108 
109  protected:
111 
114  void setLambdaPiPi( const Double_t lambda );
115 
117 
120  Double_t getLambdaPiPi() const { return ( lambdaPiPi_ != 0 ) ? lambdaPiPi_->value() : 0.0; }
121 
123 
126  Bool_t fixLambdaPiPi() const { return ( lambdaPiPi_ != 0 ) ? lambdaPiPi_->fixed() : kTRUE; }
127 
129 
132  void setLambdaKK( const Double_t lambda );
133 
135 
138  Double_t getLambdaKK() const { return ( lambdaKK_ != 0 ) ? lambdaKK_->value() : 0.0; }
139 
141 
144  Bool_t fixLambdaKK() const { return ( lambdaKK_ != 0 ) ? lambdaKK_->fixed() : kTRUE; }
145 
147 
150  void setMs( const Double_t Ms );
151 
153 
156  Double_t getMs() const { return ( Ms_ != 0 ) ? Ms_->value() : 0.0; }
157 
159 
162  Bool_t fixMs() const { return ( Ms_ != 0 ) ? Ms_->fixed() : kTRUE; }
163 
165 
168  void setMf( const Double_t Mf );
169 
171 
174  Double_t getMf() const { return ( Mf_ != 0 ) ? Mf_->value() : 0.0; }
175 
177 
180  Bool_t fixMf() const { return ( Mf_ != 0 ) ? Mf_->fixed() : kTRUE; }
181 
183 
186  void setMprime( const Double_t Mprime );
187 
189 
192  Double_t getMprime() const { return ( Mprime_ != 0 ) ? Mprime_->value() : 0.0; }
193 
195 
198  Bool_t fixMprime() const { return ( Mprime_ != 0 ) ? Mprime_->fixed() : kTRUE; }
199 
201 
204  void setEps1( const Double_t Eps1 );
205 
207 
210  Double_t getEps1() const { return ( Eps1_ != 0 ) ? Eps1_->value() : 0.0; }
211 
213 
216  Bool_t fixEps1() const { return ( Eps1_ != 0 ) ? Eps1_->fixed() : kTRUE; }
217 
219 
222  void setEps2( const Double_t Eps2 );
223 
225 
228  Double_t getEps2() const { return ( Eps2_ != 0 ) ? Eps2_->value() : 0.0; }
229 
231 
234  Bool_t fixEps2() const { return ( Eps2_ != 0 ) ? Eps2_->fixed() : kTRUE; }
235 
237 
240  void setC0( const Double_t C0 );
241 
243 
246  Double_t getC0() const { return ( C0_ != 0 ) ? C0_->value() : 0.0; }
247 
249 
252  Bool_t fixC0() const { return ( C0_ != 0 ) ? C0_->fixed() : kTRUE; }
253 
255 
259  virtual LauComplex resAmp( Double_t mass, Double_t spinTerm );
260 
261  private:
264 
267 
270 
273 
276 
279 
282 
285 
288 
291 
294 
295  ClassDef( LauRescatteringRes, 0 )
296 };
297 
298 #endif
virtual LauComplex amplitude(const LauKinematics *kinematics)
Get the complex dynamical amplitude.
LauAbsResonance::LauResonanceModel model_
The model to use.
LauParameter * C0_
the term for the C0
Class for defining the fit parameter objects.
Definition: LauParameter.hh:49
void setLambdaKK(const Double_t lambda)
Set the parameter lambdaKK, the term for the KK.
virtual LauParameter * getResonanceParameter(const TString &name)
Access the given resonance parameter.
Double_t value() const
The value of the parameter.
virtual const std::vector< LauParameter * > & getFloatingParameters()
Retrieve the resonance parameters, e.g. so that they can be loaded into a fit.
Bool_t fixMprime() const
See if the Mprime parameter is fixed or floating.
Bool_t fixMs() const
See if the Ms parameter is fixed or floating.
Double_t getC0() const
Get the C0.
LauParameter * Eps2_
the term for the Eps2
File containing declaration of LauAbsResonance class.
LauRescatteringRes & operator=(const LauRescatteringRes &rhs)
Copy assignment operator (not implemented)
void setEps1(const Double_t Eps1)
Set the parameter Eps1.
LauParameter * Mf_
the term for the Mf_
LauRescatteringRes(LauResonanceInfo *resInfo, const LauAbsResonance::LauResonanceModel resType, const Int_t resPairAmpInt, const LauDaughters *daughters)
Constructor.
void setMprime(const Double_t Mprime)
Set the parameter Mprime.
Double_t getLambdaPiPi() const
Get the lambdaPiPi, the term for the PiPi.
void setMf(const Double_t Mf)
Set the parameter Mf.
Bool_t fixEps2() const
See if the Eps2 parameter is fixed or floating.
Double_t getMf() const
Get the Mf.
Class for defining a complex number.
Definition: LauComplex.hh:61
Double_t getMprime() const
Get the Mprime.
Bool_t fixLambdaPiPi() const
See if the lambdaPiPi parameter is fixed or floating.
Bool_t fixLambdaKK() const
See if the lambdaKK parameter is fixed or floating.
Double_t getMs() const
Get the Ms.
virtual void floatResonanceParameter(const TString &name)
Allow the various parameters to float in the fit.
virtual void initialise()
Initialise the model.
Double_t getEps2() const
Get the Eps2.
Bool_t fixEps1() const
See if the Eps1 parameter is fixed or floating.
File containing declaration of LauComplex class.
LauParameter * Eps1_
the term for the Eps1
Bool_t fixed() const
Check whether the parameter is fixed or floated.
Class for defining the properties of a resonant particle.
virtual LauAbsResonance::LauResonanceModel getResonanceModel() const
Get the resonance model type.
LauParameter * lambdaPiPi_
the term for the PiPi
LauParameter * lambdaKK_
the term for the KK
void setEps2(const Double_t Eps2)
Set the parameter Eps2.
LauParameter * Ms_
the term for the Ms
LauParameter * Mprime_
the term for the Mprime
void setLambdaPiPi(const Double_t lambda)
Set the parameter lambdaPiPi, the term for the PiPi.
Double_t getLambdaKK() const
Get the lambdaKK, the term for the KK.
Double_t getEps1() const
Get the Eps1.
Abstract class for defining type for resonance amplitude models (Breit-Wigner, Flatte etc....
Class for defining the rescattering model.
virtual LauComplex resAmp(Double_t mass, Double_t spinTerm)
Complex resonant amplitude.
virtual void setResonanceParameter(const TString &name, const Double_t value)
Set value of the various parameters.
Class for calculating 3-body kinematic quantities.
Bool_t fixC0() const
See if the C0 parameter is fixed or floating.
LauRescatteringRes(const LauRescatteringRes &rhs)
Copy constructor (not implemented)
virtual ~LauRescatteringRes()
Destructor.
Class that defines the particular 3-body decay under study.
Definition: LauDaughters.hh:47
void setMs(const Double_t Ms)
Set the parameter Ms.
void setC0(const Double_t C0)
Set the parameter C0.
LauResonanceModel
Define the allowed resonance types.
Bool_t fixMf() const
See if the Mf parameter is fixed or floating.