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

Last change on this file since 836 was 819, checked in by garnier, 16 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.