source: trunk/source/processes/hadronic/models/util/include/G4ExcitedString.hh@ 880

Last change on this file since 880 was 819, checked in by garnier, 17 years ago

import all except CVS

File size: 6.6 KB
Line 
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//
28
29#ifndef G4ExcitedString_h
30#define G4ExcitedString_h 1
31
32// ------------------------------------------------------------
33// GEANT 4 class header file
34//
35// ---------------- G4ExcitedString ----------------
36// by Gunter Folger, June 1998.
37// class for an excited string used by Parton String Models
38// ------------------------------------------------------------
39
40#include "G4ios.hh"
41#include "globals.hh"
42#include "G4ThreeVector.hh"
43#include "G4LorentzVector.hh"
44#include "G4LorentzRotation.hh"
45#include "G4Parton.hh"
46#include "G4PartonVector.hh"
47#include "G4KineticTrack.hh"
48#include "G4HadronicException.hh"
49#include <algorithm>
50
51class G4ExcitedString
52{
53
54 public:
55
56 enum {
57 PROJECTILE = 1,
58 TARGET = -1
59 };
60
61 G4ExcitedString(G4Parton* Color, G4Parton* Gluon, G4Parton* AntiColor, G4int Direction=PROJECTILE);
62 G4ExcitedString(G4Parton* Color, G4Parton* AntiColor, G4int Direction=PROJECTILE);
63 G4ExcitedString(G4KineticTrack * atrack);
64
65 G4ExcitedString(const G4ExcitedString &right);
66
67 ~G4ExcitedString();
68
69 int operator==(const G4ExcitedString &right) const;
70
71 int operator!=(const G4ExcitedString &right) const;
72
73 const G4ThreeVector & GetPosition() const;
74
75 void SetPosition(const G4ThreeVector &aPosition);
76
77 const G4PartonVector * GetPartonList() const;
78
79 G4LorentzVector Get4Momentum() const;
80 void LorentzRotate(const G4LorentzRotation & rotation);
81
82 void InsertParton(G4Parton * aParton, const G4Parton * addafter = NULL);
83
84 G4LorentzRotation TransformToCenterOfMass();
85 G4LorentzRotation TransformToAlignedCms();
86
87
88 void Boost(G4ThreeVector& Velocity);
89
90 G4Parton* GetColorParton(void) const;
91 G4Parton* GetGluon(void) const;
92 G4Parton* GetAntiColorParton(void) const;
93 G4Parton* GetGluon(G4int GluonPos) const;
94
95 G4KineticTrack * GetKineticTrack() const;
96
97 G4Parton* GetLeftParton(void) const;
98 G4Parton* GetRightParton(void) const;
99
100 G4bool IsItKinkyString(void) const;
101 G4int GetDirection(void) const;
102
103 G4bool IsExcited() const;
104
105
106 private:
107
108 G4int theDirection; // must be 1 or -1 (PROJECTILE or TARGET)
109 G4ThreeVector thePosition;
110 G4PartonVector thePartons; // would like initial capacity for 3 Partons.
111 G4KineticTrack* theTrack;
112
113};
114
115inline
116int G4ExcitedString::operator==(const G4ExcitedString &right) const
117{
118 return this == &right;
119}
120
121inline
122int G4ExcitedString::operator!=(const G4ExcitedString &right) const
123{
124 return this != &right;
125}
126
127inline
128const G4ThreeVector & G4ExcitedString::GetPosition() const
129{
130 return thePosition;
131}
132
133inline
134void G4ExcitedString::SetPosition(const G4ThreeVector &aPosition)
135{
136 thePosition= aPosition;
137}
138
139inline
140G4LorentzVector G4ExcitedString::Get4Momentum() const
141{
142 G4LorentzVector momentum;
143 for ( unsigned int index=0; index < thePartons.size() ; index++ )
144 {
145 // std::cout << "HPW "<<thePartons[index]->Get4Momentum()<<std::endl;
146 momentum += thePartons[index]->Get4Momentum();
147 }
148 return momentum;
149}
150
151inline
152void G4ExcitedString::LorentzRotate(const G4LorentzRotation & rotation)
153{
154 for ( unsigned int index=0; index < thePartons.size() ; index++ )
155 {
156 thePartons[index]->Set4Momentum(rotation*thePartons[index]->Get4Momentum());
157 }
158}
159
160inline
161void G4ExcitedString::InsertParton(G4Parton *aParton, const G4Parton * addafter)
162{
163
164 G4PartonVector::iterator insert_index;
165
166 if ( addafter != NULL )
167 {
168 insert_index=std::find(thePartons.begin(), thePartons.end(), addafter);
169 if (insert_index == thePartons.end()) // No object addafter in thePartons
170 {
171 G4String text = "G4ExcitedString::InsertParton called with invalid second argument";
172 throw G4HadronicException(__FILE__, __LINE__, text);
173 }
174 }
175
176 thePartons.insert(insert_index+1, aParton);
177}
178
179inline
180G4LorentzRotation G4ExcitedString::TransformToCenterOfMass()
181{
182 G4LorentzVector momentum=Get4Momentum();
183 G4LorentzRotation toCms(-1*momentum.boostVector());
184
185 for ( unsigned int index=0; index < thePartons.size() ; index++ )
186 {
187 momentum=toCms * thePartons[index]->Get4Momentum();
188 thePartons[index]->Set4Momentum(momentum);
189 }
190 return toCms;
191}
192
193inline
194G4LorentzRotation G4ExcitedString::TransformToAlignedCms()
195{
196 G4LorentzVector momentum=Get4Momentum();
197 G4LorentzRotation toAlignedCms(-1*momentum.boostVector());
198
199 momentum= toAlignedCms* thePartons[0]->Get4Momentum();
200 toAlignedCms.rotateZ(-1*momentum.phi());
201 toAlignedCms.rotateY(-1*momentum.theta());
202
203 for ( unsigned int index=0; index < thePartons.size() ; index++ )
204 {
205 momentum=toAlignedCms * thePartons[index]->Get4Momentum();
206 thePartons[index]->Set4Momentum(momentum);
207 }
208 return toAlignedCms;
209}
210
211
212inline
213const G4PartonVector * G4ExcitedString::GetPartonList() const
214{
215 return &thePartons;
216}
217
218inline
219G4KineticTrack * G4ExcitedString::GetKineticTrack() const
220{
221 return theTrack;
222}
223
224inline
225G4bool G4ExcitedString::IsExcited() const
226{
227 return theTrack == 0;
228}
229
230
231#endif
232
233
Note: See TracBrowser for help on using the repository browser.