3 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
11 class AliALIFE : public TObject {
13 AliALIFE(const char *name1, const char *name2);
15 AliALIFE(const AliALIFE &rhs) : TObject(rhs) {
18 virtual ~AliALIFE() {}
19 void Cylinder(Float_t rmin, Float_t rmax,
20 Float_t zmin, Float_t zmax,
23 const char* Field="MF",
24 const char* Cuts="$UNSHIELDED");
25 void OnionCylinder(Float_t* r, Int_t nr, Float_t zmin, Float_t zmax,
27 const char** Materials,
28 const char** Fields=0,
31 void Cone(Float_t rmin1, Float_t rmin2,
32 Float_t rmax1, Float_t rmax2,
33 Float_t zmin, Float_t zmax,
36 const char* Field="MF",
37 const char* Cuts="$UNSHIELDED");
39 void OnionCone(Float_t* r1, Float_t* r2, Int_t nr,
40 Float_t zmin, Float_t zmax,
42 const char** Materials,
43 const char** Fields=0,
46 void PolyCone(Float_t* rmin, Float_t* rmax, Float_t* z, Int_t nz,
49 const char* Field="MF",
50 const char* Cuts="$UNSHIELDED");
52 void OnionPolyCone(Float_t** r , Float_t* z, Int_t nr, Int_t nz,
54 const char** Materials,
55 const char** Fields=0,
58 void Comment(const char* Comment);
60 void Finish(Bool_t remove = 0);
62 void SetDefaultVolume(TString vol1, TString vol2)
63 {fDefaultVolume1=vol1; fDefaultVolume2=vol2;}
65 void SetDefaultVolume(TString vol)
66 {fDefaultVolume1=vol;}
69 Int_t fNBodies; // current number of bodies
70 Int_t fNVolumes; // current number of volumes
71 TString fBodyFile; // File for Fluka bodies
72 TString fVolumeFile; // File for Fluka volumes
73 FILE *fFile1; // ! output file for fluka geometry in ALIFE format
74 FILE *fFile2; // ! scratch file
75 TString fDefaultVolume1; // default external volume 1
76 TString fDefaultVolume2; // default external volume 2
80 void Copy(TObject &alife) const;
82 AliALIFE & operator = (const AliALIFE &rhs) {