laura is hosted by Hepforge, IPPP Durham
Laura++  3.6.0
A maximum likelihood fitting package for performing Dalitz-plot analysis.
LauRhoOmegaMix.hh
Go to the documentation of this file.
1 
2 /*
3 Copyright 2016 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_RHO_OMEGA_MIX
37 #define LAU_RHO_OMEGA_MIX
38 
39 #include "LauAbsResonance.hh"
40 #include "LauComplex.hh"
41 
42 #include "TString.h"
43 
44 #include <vector>
45 
46 class LauResonanceInfo;
47 class LauDaughters;
48 class LauParameter;
49 
51 
52  public:
54 
62  const Int_t resPairAmpInt,
63  const LauDaughters* daughters );
64 
66  virtual ~LauRhoOmegaMix();
67 
69  virtual void initialise();
70 
72  void initialiseRho();
73 
75  void initialiseOmega();
76 
78 
82  virtual LauComplex amplitude( const LauKinematics* kinematics );
83 
85 
89 
91 
95  virtual void setResonanceParameter( const TString& name, const Double_t value );
96 
98 
101  virtual void floatResonanceParameter( const TString& name );
102 
104 
108  virtual LauParameter* getResonanceParameter( const TString& name );
109 
111 
114  virtual const std::vector<LauParameter*>& getFloatingParameters();
115 
117  void setWhichAmpSq( Int_t which ) { whichAmpSq_ = which; }
118 
119  protected:
121 
124  void setmOmegaValue( const Double_t mOmega );
125 
127 
130  Double_t getmOmegaValue() const { return ( mOmega_ != 0 ) ? mOmega_->unblindValue() : 0.0; }
131 
133 
136  Bool_t fixmOmegaValue() const { return ( mOmega_ != 0 ) ? mOmega_->fixed() : 0.0; }
137 
139 
142  void setwOmegaValue( const Double_t wOmega );
143 
145 
148  Double_t getwOmegaValue() const { return ( wOmega_ != 0 ) ? wOmega_->unblindValue() : 0.0; }
149 
151 
154  Bool_t fixwOmegaValue() const { return ( wOmega_ != 0 ) ? wOmega_->fixed() : 0.0; }
155 
157 
160  void setmagBValue( const Double_t magB );
161 
163 
166  Double_t getmagBValue() const { return ( magB_ != 0 ) ? magB_->unblindValue() : 0.0; }
167 
169 
172  Bool_t fixmagBValue() const { return ( magB_ != 0 ) ? magB_->fixed() : 0.0; }
173 
175 
178  void setphiBValue( const Double_t phiB );
179 
181 
184  Double_t getphiBValue() const { return ( phiB_ != 0 ) ? phiB_->unblindValue() : 0.0; }
185 
187 
190  Bool_t fixphiBValue() const { return ( phiB_ != 0 ) ? phiB_->fixed() : 0.0; }
191 
193 
196  void setdeltaValue( const Double_t delta );
197 
199 
202  Double_t getdeltaValue() const { return ( delta_ != 0 ) ? delta_->unblindValue() : 0.0; }
203 
205 
208  Bool_t fixdeltaValue() const { return ( delta_ != 0 ) ? delta_->fixed() : 0.0; }
209 
211  virtual LauComplex resAmp( Double_t mass, Double_t spinTerm );
212 
214  void checkDaughterTypes() const;
215 
216  private:
219 
222 
225 
227  Double_t rhoMass_;
228 
230  Double_t rhoResRadius_;
231 
233  Double_t rhoParRadius_;
234 
237 
239  Double_t mOmega0_;
240 
242  Double_t mOmegaCur_;
243 
246 
248  Double_t wOmega0_;
249 
251  Double_t wOmegaCur_;
252 
255 
258 
261 
263  Bool_t useDenom_;
264 
267 
270 
273 
275  Int_t whichAmpSq_;
276 
277  ClassDef( LauRhoOmegaMix, 0 ) // Rho-omega mixing model
278 };
279 
280 #endif
LauAbsResonance * rhoRes_
Pointer to the rho (or first) resonance lineshape.
LauParameter * wOmega_
Pole width of the omega contribution.
Class for defining the fit parameter objects.
Definition: LauParameter.hh:49
Double_t unblindValue() const
The unblinded value of the parameter.
virtual LauParameter * getResonanceParameter(const TString &name)
Access the given resonance parameter.
virtual ~LauRhoOmegaMix()
Destructor.
Bool_t useDenom_
Boolean to specify if we want to use the denominator factor.
Double_t wOmega0_
Initial default value of the omega pole width from LauResonanceMaker.
LauRhoOmegaMix & operator=(const LauRhoOmegaMix &rhs)
Copy assignment operator (not implemented)
Class for defining the rho-omega resonance mixing model.
void checkDaughterTypes() const
Check that both daughters are the same type of particle.
LauParameter * magB_
B magnitude parameter of the omega mixing contribution.
Bool_t fixwOmegaValue() const
Fix the omega pole width parameter value.
LauParameter * mOmega_
Pole mass of the omega contribution.
File containing declaration of LauAbsResonance class.
Double_t rhoParRadius_
Previous value of the parents barrier radius of the rho resonance.
LauParameter * delta_
delta parameter of the omega mixing contribution
Double_t getdeltaValue() const
Get the omega mixing parameter delta.
virtual LauAbsResonance::LauResonanceModel getResonanceModel() const
Get the resonance model type.
Double_t getwOmegaValue() const
Get the omega pole width parameter value.
LauAbsResonance::LauResonanceModel model_
The model to use.
LauAbsResonance * omegaRes_
Pointer to the omega (second) resonance lineshape.
Bool_t fixmagBValue() const
Fix the omega B magnitude mixing parameter value.
Class for defining a complex number.
Definition: LauComplex.hh:61
virtual const std::vector< LauParameter * > & getFloatingParameters()
Retrieve the resonance parameters, e.g. so that they can be loaded into a fit.
void setmOmegaValue(const Double_t mOmega)
Set the omega pole mass parameter.
Bool_t doneFirstInit_
Boolean to specify if we have performed the first initialisation.
Double_t mOmega0_
Initial default value of the omega pole mass from LauResonanceMaker.
File containing declaration of LauComplex class.
void setdeltaValue(const Double_t delta)
Set the omega mixing parameter delta.
virtual LauComplex amplitude(const LauKinematics *kinematics)
Get the complex dynamical amplitude.
Double_t mOmegaCur_
Current value of the omega pole mass (floating or fixed)
Bool_t fixed() const
Check whether the parameter is fixed or floated.
virtual void initialise()
Initialise the model.
void setWhichAmpSq(Int_t which)
Set which rho/omega amplitude to calculate for FF.
Class for defining the properties of a resonant particle.
virtual void floatResonanceParameter(const TString &name)
Allow the various parameters to float in the fit.
virtual void setResonanceParameter(const TString &name, const Double_t value)
Set value of the various parameters.
LauRhoOmegaMix(LauResonanceInfo *resInfo, const LauAbsResonance::LauResonanceModel resType, const Int_t resPairAmpInt, const LauDaughters *daughters)
Constructor.
void initialiseRho()
Initialise the rho resonance.
void setwOmegaValue(const Double_t wOmega)
Set the omega pole width parameter.
Double_t getphiBValue() const
Get the omega B phase mixing parameter.
Double_t rhoMass_
Previous value of the pole mass of the rho resonance.
Bool_t fixdeltaValue() const
Fix the omega mixing parameter delta value.
Bool_t fixphiBValue() const
Fix the omega B phase mixing parameter value.
void initialiseOmega()
Initialise the omega resonance.
Abstract class for defining type for resonance amplitude models (Breit-Wigner, Flatte etc....
Int_t whichAmpSq_
Which amplitude to calculate for rho/omega fit fractions.
LauRhoOmegaMix(const LauRhoOmegaMix &rhs)
Copy constructor (not implemented)
Class for calculating 3-body kinematic quantities.
Bool_t fixmOmegaValue() const
Fix the omega pole mass parameter value.
Class that defines the particular 3-body decay under study.
Definition: LauDaughters.hh:47
Double_t getmagBValue() const
Get the omega B magnitude mixing parameter.
void setmagBValue(const Double_t magB)
Set the omega B magnitude mixing parameter.
virtual LauComplex resAmp(Double_t mass, Double_t spinTerm)
This is not called, amplitude is used directly instead.
Double_t wOmegaCur_
Current value of the omega pole mass (floating or fixed)
LauResonanceModel
Define the allowed resonance types.
Double_t getmOmegaValue() const
Get the omega pole mass parameter value.
Double_t rhoResRadius_
Previous value of the barrier radius of the rho resonance.
LauParameter * phiB_
B phase parameter of the omega mixing contribution.
void setphiBValue(const Double_t phiB)
Set the omega B phase mixing parameter.