laura is hosted by Hepforge, IPPP Durham
Laura++  3.6.0
A maximum likelihood fitting package for performing Dalitz-plot analysis.
LauResonanceMaker.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 
35 #ifndef LAU_RESONANCE_MAKER
36 #define LAU_RESONANCE_MAKER
37 
38 #include "LauAbsResonance.hh"
39 
40 #include "TString.h"
41 
42 #include <iosfwd>
43 #include <vector>
44 
45 class LauDaughters;
46 class LauResonanceInfo;
47 
49 
50  public:
52  static LauResonanceMaker& get();
53 
55 
61 
63 
69 
71 
76  void setSpinFormalism( const LauAbsResonance::LauSpinType spinType );
77 
79 
84  const Double_t bwRadius );
85 
87 
92  const Bool_t fixRadius );
93 
95 
103  LauAbsResonance* getResonance( const LauDaughters* daughters,
104  const TString& resName,
105  const Int_t resPairAmpInt,
108  LauBlattWeisskopfFactor::Default );
109 
111 
115  Int_t resTypeInt( const TString& name ) const;
116 
118 
121  UInt_t getNResDefMax() const { return nResDefMax_; }
122 
124 
127  void printAll( std::ostream& stream ) const;
128 
130 
134  LauResonanceInfo* getResInfo( const TString& resName ) const;
135 
139 
140  protected:
142  void createResonanceVector();
143 
146  const LauResonanceInfo* resInfo );
147 
148  private:
157  Double_t defaultRadius_;
159  Bool_t radiusFixed_;
160  };
161 
163  typedef std::map<LauBlattWeisskopfFactor::BlattWeisskopfCategory, BlattWeisskopfCategoryInfo>
165 
168 
170  virtual ~LauResonanceMaker();
171 
174 
177 
180 
182  UInt_t nResDefMax_;
183 
185  std::vector<LauResonanceInfo*> resInfo_;
186 
189 
192 
195 
198 
200  std::vector<LauBlattWeisskopfFactor*> bwIndepFactors_;
201 
204 
205  ClassDef( LauResonanceMaker, 0 ) // Kinematic routines
206 };
207 
208 #endif
static LauResonanceMaker * resonanceMaker_
The singleton instance.
static LauResonanceMaker & get()
Get the factory instance.
LauResonanceMaker & operator=(const LauResonanceMaker &other)
Copy assignment (not implemented)
void printAll(std::ostream &stream) const
Print the information records, one per line, to the requested stream.
Int_t resTypeInt(const TString &name) const
Retrieve the integer index for the specified resonance.
void setDefaultBWRadius(const LauBlattWeisskopfFactor::BlattWeisskopfCategory bwCategory, const Double_t bwRadius)
Set the BW radius for the given category.
UInt_t nResDefMax_
The number of known resonances.
LauBlattWeisskopfFactor * getParentBWFactor(Int_t newSpin, LauBlattWeisskopfFactor::BarrierType barrierType)
Retrieve parent Blatt-Weisskopf factor (for use by K-matrix pole/SVP which doesn't have a ‘resInfo’)
void setBWBachelorRestFrame(const LauBlattWeisskopfFactor::RestFrame restFrame)
Set the rest frame in which the bachelor momentum should be calculated (for all BW categories)
Bool_t summaryPrinted_
Boolean flag to control printing a summary of the formalism to be used when the first resonance is cr...
File containing declaration of LauAbsResonance class.
LauBlattWeisskopfFactor::BarrierType bwBarrierType_
The type of the Blatt-Weisskopf barrier to use for all resonances.
void setSpinFormalism(const LauAbsResonance::LauSpinType spinType)
Set the spin formalism to be used for all resonances.
void createResonanceVector()
Create the list of known resonances.
std::vector< LauResonanceInfo * > resInfo_
The known resonances.
void setBWType(const LauBlattWeisskopfFactor::BarrierType bwType)
Set the type of BW factor (for all categories)
void fixBWRadius(const LauBlattWeisskopfFactor::BlattWeisskopfCategory bwCategory, const Bool_t fixRadius)
Fix or release the Blatt-Weisskopf barrier radius for the given category.
Bool_t radiusFixed_
Whether or not the radius value for this category should be fixed in the fit.
LauAbsResonance::LauSpinType spinFormalism_
The spin formalism that should be used for all resonances.
LauAbsResonance * getResonance(const LauDaughters *daughters, const TString &resName, const Int_t resPairAmpInt, const LauAbsResonance::LauResonanceModel resType, const LauBlattWeisskopfFactor::BlattWeisskopfCategory bwCategory=LauBlattWeisskopfFactor::Default)
Create a resonance.
Data structure to store information on a given Blatt-Weisskopf category.
BarrierType
Define the allowed types of barrier factors.
LauResonanceMaker()
Constructor.
Double_t defaultRadius_
The default value for the radius in this category.
std::map< LauBlattWeisskopfFactor::BlattWeisskopfCategory, BlattWeisskopfCategoryInfo > BWFactorCategoryMap
Define a type to hold information on each BW category.
Class for defining the properties of a resonant particle.
UInt_t getNResDefMax() const
Retrieve the number of defined resonances.
Singleton factory class for creating resonances.
BlattWeisskopfCategory
Define resonance categories that will share common barrier factor radii.
LauSpinType
Define the allowed spin formalisms.
Abstract class for defining type for resonance amplitude models (Breit-Wigner, Flatte etc....
LauBlattWeisskopfFactor * getBWFactor(const LauBlattWeisskopfFactor::BlattWeisskopfCategory bwCategory, const LauResonanceInfo *resInfo)
Retrieve Blatt-Weisskopf factor for the given category.
virtual ~LauResonanceMaker()
Destructor.
Class that defines the particular 3-body decay under study.
Definition: LauDaughters.hh:47
LauResonanceMaker(const LauResonanceMaker &other)
Copy constructor (not inplemented)
LauResonanceInfo * getResInfo(const TString &resName) const
Get the information for the given resonance name.
BWFactorCategoryMap bwFactors_
The Blatt-Weisskopf factor objects (and related information) for each category.
std::vector< LauBlattWeisskopfFactor * > bwIndepFactors_
The Blatt-Weisskopf factor objects for resonances in the independent category.
RestFrame
Define the rest frame in which the momentum should be calculated (only relevant for bachelor)
LauResonanceModel
Define the allowed resonance types.
LauBlattWeisskopfFactor * bwFactor_
The BW factor object.
LauBlattWeisskopfFactor::RestFrame bwRestFrame_
The rest frame in which the bachelor momentum used in the Blatt-Weisskopf factors should be calculate...
Class that implements the Blatt-Weisskopf barrier factor.