source: trunk/examples/advanced/composite_calorimeter/include/CCalMaterial.hh@ 807

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

update

File size: 3.5 KB
RevLine 
[807]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// File: CCalMaterial.hh
28// Description: CCalMaterial holds the basic information needed to make a
29// G4Material.
30///////////////////////////////////////////////////////////////////////////////
31#ifndef CCalMaterial_h
32#define CCalMaterial_h 1
33#include <iostream>
34#include "globals.hh"
35
36class CCalMaterial {
37
38friend std::ostream& operator<<(std::ostream&, const CCalMaterial&);
39
40public:
41 enum FractionType {FTWeight, FTVolume};
42
43 //Constructors and destructors
44 CCalMaterial(G4String mat, double dens, int nelem,
45 CCalMaterial** constituents, double* weights,
46 FractionType=FTWeight);
47 CCalMaterial(const CCalMaterial&);
48 virtual ~CCalMaterial();
49
50 //Get methods
51 G4String Name() const {return name;} //Material name.
52 double Density() const {return density;} //Density in g/cm3.
53 int NElements() const {return nElem;} //Number of Elements.
54 G4String Element(int i) const {return theElements[i];} //Should be protected.
55 double Weight(int i) const {return theWeights[i];} //Should be protected.
56
57 //Operators
58 G4bool operator==(const CCalMaterial&) const; //Compares ONLY names
59 G4bool operator!=(const CCalMaterial&) const; //Compares ONLY names
60 CCalMaterial& operator= (const CCalMaterial&); //Assignment
61
62protected:
63 CCalMaterial(){} //Default constructor
64 void computeDensity(int nconst,
65 CCalMaterial** constituents, double* weights,
66 FractionType ft);
67 void closeMaterial(); //Closes material construction.
68
69protected:
70 G4String name; //Material name
71 double density; //Density in g/cm3
72 int nElem; //Number of constituents.
73 G4String* theElements; //Basic constituents
74 double* theWeights; //Elements' weight fractions
75};
76#endif
Note: See TracBrowser for help on using the repository browser.