source: trunk/source/processes/hadronic/models/cascade/cascade/include/G4EvaporationInuclCollider.hh @ 962

Last change on this file since 962 was 962, checked in by garnier, 15 years ago

update processes

File size: 3.3 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// $Id: G4EvaporationInuclCollider.hh,v 1.2 2008/06/29 23:56:03 dennis Exp $
27#ifndef G4EVAPORATIONINUCL_COLLIDER_HH
28#define G4EVAPORATIONINUCL_COLLIDER_HH
29 
30#include "G4Collider.hh"
31
32#include "G4EquilibriumEvaporator.hh"
33#include "G4Fissioner.hh"
34#include "G4BigBanger.hh"
35
36#include "G4ElementaryParticleCollider.hh"
37#include "G4InteractionCase.hh"
38#include "G4InuclNuclei.hh"
39#include "G4InuclSpecialFunctions.hh"
40#include "G4Analyser.hh"
41
42using namespace G4InuclSpecialFunctions;
43
44class G4EvaporationInuclCollider {
45
46public:
47
48  G4EvaporationInuclCollider();
49
50  G4EvaporationInuclCollider(G4EquilibriumEvaporator* eqevaporator, G4Fissioner* fissioner, G4BigBanger* bigbanger) {
51
52    setEquilibriumEvaporator(eqevaporator, fissioner, bigbanger);
53  };
54
55  void setEquilibriumEvaporator(G4EquilibriumEvaporator* eqevaporator, G4Fissioner* fissioner, G4BigBanger* bigbanger) {
56    theEquilibriumEvaporator = eqevaporator;
57    theEquilibriumEvaporator->setFissioner(fissioner);   
58    theEquilibriumEvaporator->setBigBanger(bigbanger);   
59  };
60
61  void setBigBanger(G4BigBanger* bigbanger) {
62
63    theBigBanger = bigbanger;   
64  };
65 
66  G4CollisionOutput collide(G4InuclParticle* bullet, G4InuclParticle* target);
67 
68private: 
69
70  G4int verboseLevel;
71
72  G4bool inelasticInteractionPossible(G4InuclParticle* bullet,
73                                      G4InuclParticle* target, 
74                                      G4double ekin) const;
75
76  G4InteractionCase bulletTargetSetter(G4InuclParticle* bullet,
77                                       G4InuclParticle* target) const; 
78
79  G4bool explosion(G4InuclNuclei* target) const; 
80       
81  G4EquilibriumEvaporator* theEquilibriumEvaporator;
82  G4BigBanger* theBigBanger;
83
84};       
85
86#endif // G4EVAPORATIONINUCL_COLLIDER_HH
87
88
Note: See TracBrowser for help on using the repository browser.