Geant4  9.6.p02
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4PenelopeOscillator.hh
Go to the documentation of this file.
1 //
2 // ********************************************************************
3 // * License and Disclaimer *
4 // * *
5 // * The Geant4 software is copyright of the Copyright Holders of *
6 // * the Geant4 Collaboration. It is provided under the terms and *
7 // * conditions of the Geant4 Software License, included in the file *
8 // * LICENSE and available at http://cern.ch/geant4/license . These *
9 // * include a list of copyright holders. *
10 // * *
11 // * Neither the authors of this software system, nor their employing *
12 // * institutes,nor the agencies providing financial support for this *
13 // * work make any representation or warranty, express or implied, *
14 // * regarding this software system or assume any liability for its *
15 // * use. Please see the license in the file LICENSE and URL above *
16 // * for the full disclaimer and the limitation of liability. *
17 // * *
18 // * This code implementation is the result of the scientific and *
19 // * technical work of the GEANT4 collaboration. *
20 // * By using, copying, modifying or distributing the software (or *
21 // * any work based on the software) you agree to acknowledge its *
22 // * use in resulting scientific publications, and indicate your *
23 // * acceptance of all terms of the Geant4 Software license. *
24 // ********************************************************************
25 //
26 //
27 // Author: Luciano Pandola
28 //
29 // History:
30 // -----------
31 // 18 Dec 2008 L. Pandola First implementation
32 //
33 //
34 // -------------------------------------------------------------------
35 //
36 // Class description:
37 // Class designed to contain data of atomic oscillators that are used by
38 // several Penelope models. Objects of G4PenelopeOscillators are managed
39 // by a dedicated G4PenelopeOscillatorManager.
40 // -------------------------------------------------------------------
41 
42 #ifndef G4PENELOPEOSCILLATOR_HH
43 #define G4PENELOPEOSCILLATOR_HH 1
44 
45 #include "globals.hh"
46 
48 {
49 
50  public:
53 
55 
56  //I need to overload the following operators: > < == =
58  int operator==(const G4PenelopeOscillator&) const;
59  int operator>(const G4PenelopeOscillator&) const;
60  int operator<(const G4PenelopeOscillator&) const;
61 
62  //Setters and getters
63  G4double GetHartreeFactor() {return hartreeFactor;};
64  void SetHartreeFactor(G4double hf) {hartreeFactor = hf;};
65  //
66  G4double GetIonisationEnergy() {return ionisationEnergy;};
67  void SetIonisationEnergy(G4double ie) {ionisationEnergy = ie;};
68  //
69  G4double GetResonanceEnergy() const {return resonanceEnergy;};
70  void SetResonanceEnergy(G4double re) {resonanceEnergy = re;};
71  //
72  G4double GetOscillatorStrength() {return oscillatorStrength;};
73  void SetOscillatorStrength(G4double ostr) {oscillatorStrength=ostr;};
74  //
75  G4int GetShellFlag() {return shellFlag;};
76  void SetShellFlag(G4int theflag) {shellFlag=theflag;};
77  //
78  G4double GetParentZ() {return parentZ;};
79  void SetParentZ(G4double parZ) {parentZ = parZ;};
80  //
81  G4int GetParentShellID() {return parentShellID;};
82  void SetParentShellID(G4int psID) {parentShellID = psID;};
83  //
84  G4double GetCutoffRecoilResonantEnergy(){return cutoffRecoilResonantEnergy;};
85  void SetCutoffRecoilResonantEnergy(G4double ene){cutoffRecoilResonantEnergy = ene;};
86 
87 private:
88  G4double hartreeFactor;
89  G4double ionisationEnergy;
90  G4double resonanceEnergy;
91  G4double oscillatorStrength;
92  G4int shellFlag;
93  G4double parentZ;
94  G4int parentShellID; //necessary for interface to AtomicDeexcitationManager
95  G4double cutoffRecoilResonantEnergy;
96 };
97 
99 {
100 public:
102  const G4PenelopeOscillator& right)
103  {return ((left.GetResonanceEnergy() < right.GetResonanceEnergy()) ? 1 : 0);};
104 };
105 
106 #endif
107