laura is hosted by Hepforge, IPPP Durham
Laura++  3.6.0
A maximum likelihood fitting package for performing Dalitz-plot analysis.
LauLASSRes.hh
Go to the documentation of this file.
1 
2 /*
3 Copyright 2004 University of Warwick
4 
5 Licensed under the Apache License, Version 2.0 (the "License");
6 you may not use this file except in compliance with the License.
7 You may obtain a copy of the License at
8 
9  http://www.apache.org/licenses/LICENSE-2.0
10 
11 Unless required by applicable law or agreed to in writing, software
12 distributed under the License is distributed on an "AS IS" BASIS,
13 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 See the License for the specific language governing permissions and
15 limitations under the License.
16 */
17 
18 /*
19 Laura++ package authors:
20 John Back
21 Paul Harrison
22 Thomas Latham
23 */
24 
36 #ifndef LAU_LASS_RES
37 #define LAU_LASS_RES
38 
39 #include "LauAbsResonance.hh"
40 #include "LauComplex.hh"
41 
42 #include "TString.h"
43 
44 class LauLASSRes : public LauAbsResonance {
45 
46  public:
48 
53  LauLASSRes( LauResonanceInfo* resInfo, const Int_t resPairAmpInt, const LauDaughters* daughters );
54 
56  virtual ~LauLASSRes();
57 
59  virtual void initialise();
60 
62 
66  {
67  return LauAbsResonance::LASS;
68  }
69 
71 
74  Double_t getCutOff() const { return cutOff_; }
75 
77 
80  void setCutOff( const Double_t cutOff ) { cutOff_ = cutOff; }
81 
83 
87  virtual void setResonanceParameter( const TString& name, const Double_t value );
88 
90 
93  virtual void floatResonanceParameter( const TString& name );
94 
96 
100  virtual LauParameter* getResonanceParameter( const TString& name );
101 
103 
106  virtual const std::vector<LauParameter*>& getFloatingParameters();
107 
108  protected:
110 
113  void setEffectiveRange( const Double_t r );
114 
116 
119  void setScatteringLength( const Double_t a );
120 
122 
125  Double_t getEffectiveRange() const { return ( r_ != 0 ) ? r_->unblindValue() : 0.0; }
126 
128 
131  Double_t getScatteringLength() const { return ( a_ != 0 ) ? a_->unblindValue() : 0.0; }
132 
134 
137  Bool_t fixEffectiveRange() const { return ( r_ != 0 ) ? r_->fixed() : kTRUE; }
138 
140 
143  Bool_t fixScatteringLength() const { return ( a_ != 0 ) ? a_->fixed() : kTRUE; }
144 
146  void calcQ0();
147 
149 
153  virtual LauComplex resAmp( Double_t mass, Double_t spinTerm );
154 
155  private:
157  LauLASSRes( const LauLASSRes& rhs );
158 
161 
163  Double_t q0_;
165  Double_t mDaugSum_;
167  Double_t mDaugSumSq_;
169  Double_t mDaugDiff_;
171  Double_t mDaugDiffSq_;
173  Double_t resMass_;
175  Double_t resMassSq_;
176 
181 
183  Double_t cutOff_;
184 
185  ClassDef( LauLASSRes, 0 )
186 };
187 
188 #endif
virtual ~LauLASSRes()
Destructor.
Definition: LauLASSRes.cc:76
Double_t getScatteringLength() const
Get the scattering length range parameter.
Definition: LauLASSRes.hh:131
Class for defining the fit parameter objects.
Definition: LauParameter.hh:49
Double_t unblindValue() const
The unblinded value of the parameter.
virtual LauAbsResonance::LauResonanceModel getResonanceModel() const
Get the resonance model type.
Definition: LauLASSRes.hh:65
Double_t resMass_
The resonance mass.
Definition: LauLASSRes.hh:173
virtual LauComplex resAmp(Double_t mass, Double_t spinTerm)
Complex resonant amplitude.
Definition: LauLASSRes.cc:116
Double_t getCutOff() const
Get the cut off parameter.
Definition: LauLASSRes.hh:74
File containing declaration of LauAbsResonance class.
virtual void initialise()
Initialise the model.
Definition: LauLASSRes.cc:80
Bool_t fixEffectiveRange() const
See if the effective range parameter is fixed or floating.
Definition: LauLASSRes.hh:137
void setEffectiveRange(const Double_t r)
Set the effective range parameter value.
Definition: LauLASSRes.cc:271
Double_t resMassSq_
Square of the resonance mass.
Definition: LauLASSRes.hh:175
Double_t mDaugDiff_
Difference between the daughter masses.
Definition: LauLASSRes.hh:169
virtual void floatResonanceParameter(const TString &name)
Allow the various parameters to float in the fit.
Definition: LauLASSRes.cc:234
Class for defining a complex number.
Definition: LauComplex.hh:61
Bool_t fixScatteringLength() const
See if the scattering length parameter is fixed or floating.
Definition: LauLASSRes.hh:143
Double_t mDaugDiffSq_
Square of mDaugDiff.
Definition: LauLASSRes.hh:171
LauLASSRes(const LauLASSRes &rhs)
Copy constructor (not implemented)
LauParameter * r_
LASS effective range parameter.
Definition: LauLASSRes.hh:178
File containing declaration of LauComplex class.
void setScatteringLength(const Double_t a)
Set the scattering length parameter value.
Definition: LauLASSRes.cc:278
Double_t cutOff_
LASS cut off.
Definition: LauLASSRes.hh:183
LauLASSRes & operator=(const LauLASSRes &rhs)
Copy assignment operator (not implemented)
Double_t mDaugSum_
Sum of the daughter masses.
Definition: LauLASSRes.hh:165
virtual void setResonanceParameter(const TString &name, const Double_t value)
Set value of a resonance parameter.
Definition: LauLASSRes.cc:217
LauParameter * a_
LASS scattering length parameter.
Definition: LauLASSRes.hh:180
Bool_t fixed() const
Check whether the parameter is fixed or floated.
void setCutOff(const Double_t cutOff)
Set the cut off parameter.
Definition: LauLASSRes.hh:80
Class for defining the properties of a resonant particle.
virtual const std::vector< LauParameter * > & getFloatingParameters()
Retrieve the resonance parameters, e.g. so that they can be loaded into a fit.
Definition: LauLASSRes.cc:194
Abstract class for defining type for resonance amplitude models (Breit-Wigner, Flatte etc....
Double_t getEffectiveRange() const
Get the effective range parameter.
Definition: LauLASSRes.hh:125
Double_t mDaugSumSq_
Square of mDaugSum.
Definition: LauLASSRes.hh:167
Double_t q0_
Decay momentum of either daughter in the resonance rest frame.
Definition: LauLASSRes.hh:163
virtual LauParameter * getResonanceParameter(const TString &name)
Access the given resonance parameter.
Definition: LauLASSRes.cc:258
Class that defines the particular 3-body decay under study.
Definition: LauDaughters.hh:47
void calcQ0()
Utility function to calculate the q0 value.
Definition: LauLASSRes.cc:104
LauResonanceModel
Define the allowed resonance types.
Class for defining the LASS resonance model.
Definition: LauLASSRes.hh:44
LauLASSRes(LauResonanceInfo *resInfo, const Int_t resPairAmpInt, const LauDaughters *daughters)
Constructor.
Definition: LauLASSRes.cc:36