CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
List of all members | Public Types | Public Member Functions | Friends
DDMaterial Class Reference

DDMaterial is used to define and access material information. More...

#include <DDMaterial.h>

Inheritance diagram for DDMaterial:
DDBase< DDName, std::unique_ptr< DDI::Material > >

Public Types

using FractionV = std::vector< std::pair< DDMaterial, double >>
 
- Public Types inherited from DDBase< DDName, std::unique_ptr< DDI::Material > >
using def_type = std::pair< const DDName *, bool >
 
using StoreT = DDI::Singleton< DDI::Store< DDName, std::unique_ptr< DDI::Material > > >
 

Public Member Functions

double a () const
 returns the atomic mass More...
 
int addMaterial (const DDMaterial &m, double fm)
 adds a material to the mixture proportional to its fraction-mass fm. More...
 
FractionV::value_type constituent (int i) const
 returns the i-th compound material and its fraction-mass More...
 
 DDMaterial ()
 Creates a uninitialized reference-object (see DDLogicalPart documentation for details on reference objects) More...
 
 DDMaterial (const DDName &name)
 Creates a initialized reference-object or a reference to an allready defined material. More...
 
 DDMaterial (const DDName &name, double z, double a, double d)
 Constructor for construction of an elementary material. More...
 
 DDMaterial (const DDName &name, double density)
 Constructor for mixtures. More...
 
double density () const
 returns the density More...
 
int noOfConstituents () const
 returns the number of compound materials or 0 for elementary materials More...
 
double z () const
 retruns the atomic number More...
 
- Public Member Functions inherited from DDBase< DDName, std::unique_ptr< DDI::Material > >
void create (const DDName &name, std::unique_ptr< DDI::Material >vals)
 
void create (const DDName &name)
 
 DDBase ()
 
const DDNameddname () const
 
def_type isDefined () const
 
bool isValid () const
 true, if the wrapped pointer is valid More...
 
const DDNamename () const
 
 operator bool () const
 
bool operator< (const DDBase &b) const
 
bool operator== (const DDBase &b) const
 
bool operator> (const DDBase &b) const
 
const DDI::rep_traits< DDName,
std::unique_ptr< DDI::Material >
>::reference 
rep () const
 
DDI::rep_traits< DDName,
std::unique_ptr< DDI::Material >
>::reference 
rep ()
 
std::string toString () const
 
const DDI::rep_traits< DDName,
std::unique_ptr< DDI::Material >
>::reference 
val () const
 
const DDI::rep_traits< DDName,
std::unique_ptr< DDI::Material >
>::reference 
val ()
 
virtual ~DDBase ()
 

Friends

std::ostream & operator<< (std::ostream &, const DDMaterial &)
 

Additional Inherited Members

- Static Public Member Functions inherited from DDBase< DDName, std::unique_ptr< DDI::Material > >
static auto begin ()
 
static auto end ()
 

Detailed Description

DDMaterial is used to define and access material information.

An object of this class is a reference-object and thus leightweighted. It is uniquely identified by its DDName. Further details concerning reference-objects can be found in the documentation of DDLogicalPart.

A DDMaterial can recursively consist of compound materials (which are DDMaterials as well). Materials consisting of compound materials are called mixtures. Mixtures are defined by their Materials which do not consist of compound materials are called elementary materials.

To define an elementray material, use it like this:

DDMaterial hydrogen("Hydrogen",
double z=1,
double a=1.1*g/mole,
density=2*g/cm3);

To define a mixture:

DDMaterial mixt("Mix", double density = 5*g/cm3);
mixt.addMaterial(hydrogen,0.3);
// code for additional compounds belonging to the mixture ...

Note the usage DDUnits replacing CLHEP/SystemOfUnits to specify the units of the quantities making up a material.

Definition at line 45 of file DDMaterial.h.

Member Typedef Documentation

using DDMaterial::FractionV = std::vector<std::pair<DDMaterial, double>>

Definition at line 49 of file DDMaterial.h.

Constructor & Destructor Documentation

DDMaterial::DDMaterial ( )

Creates a uninitialized reference-object (see DDLogicalPart documentation for details on reference objects)

Definition at line 15 of file DDMaterial.cc.

DDMaterial::DDMaterial ( const DDName name)

Creates a initialized reference-object or a reference to an allready defined material.

If a DDMaterial with name was already defined, this constructor creates a reference object to the defined material. Otherwise it creates a (default) initialized reference-object to a material with DDName name.

For further details concerning the usage of reference-objects refere to the documentation of DDLogicalPart.

Definition at line 25 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::create().

Definition: DDBase.h:10
void create(const DDName &name, std::unique_ptr< DDI::Material >vals)
Definition: DDBase.h:96
DDMaterial::DDMaterial ( const DDName name,
double  z,
double  a,
double  d 
)

Constructor for construction of an elementary material.

  • z atomic number
  • a atomic mass
  • density density

Example:

DDMaterial hydrogen("Hydrogen",
double z=1,
double a=1.1*g/mole,
density=2*g/cm3);

Definition at line 40 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::create().

41  create(name, std::make_unique<Material>(z, a, d));
42 }
Definition: DDBase.h:10
double a() const
returns the atomic mass
Definition: DDMaterial.cc:76
tuple d
Definition: ztail.py:151
double z() const
retruns the atomic number
Definition: DDMaterial.cc:78
void create(const DDName &name, std::unique_ptr< DDI::Material >vals)
Definition: DDBase.h:96
DDMaterial::DDMaterial ( const DDName name,
double  density 
)

Constructor for mixtures.

For a mixture material it is sufficient to specify the density of the mixture (in addition to the name). The compounds are added by using the addMaterial(..) method.

The result of this constructor is a reference-object. One can use the mixture material immidiately (without specifying the compund materials). Compound materials can be added at any later stage.

For further details concerning the usage of reference-objects refere to the documentation of DDLogicalPart.

Definition at line 56 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::create().

57  create(name, std::make_unique<Material>(0, 0, density));
58 }
Definition: DDBase.h:10
double density() const
returns the density
Definition: DDMaterial.cc:80
void create(const DDName &name, std::unique_ptr< DDI::Material >vals)
Definition: DDBase.h:96

Member Function Documentation

double DDMaterial::a ( ) const

returns the atomic mass

Definition at line 76 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::rep().

Referenced by DDG4Builder::convertMaterial(), TGeoMgrFromDdd::createMaterial(), DDCheckMaterial(), DDHtmlMaDetails::details(), and DDCoreToDDXMLOutput::material().

76 { return rep().a(); }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Material > >::reference rep() const
Definition: DDBase.h:65
int DDMaterial::addMaterial ( const DDMaterial m,
double  fm 
)

adds a material to the mixture proportional to its fraction-mass fm.

The fraction-masses of all compounds must sum up to 1

Definition at line 63 of file DDMaterial.cc.

References DDBase< N, C >::ddname(), DDBase< DDName, std::unique_ptr< DDI::Material > >::ddname(), Exception, and DDBase< DDName, std::unique_ptr< DDI::Material > >::rep().

Referenced by DDLCompositeMaterial::processElement(), and regressionTest_setup().

63  {
64  if (m.ddname() == ddname()) {
65  throw cms::Exception("DDException") << "DDMaterial::addMaterial(..): name-clash\n trying to add material "
66  << m << " to itself! ";
67  }
68  rep().addMaterial(m, fm);
69  return rep().noOfConstituents();
70 }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Material > >::reference rep() const
Definition: DDBase.h:65
const N & ddname() const
Definition: DDBase.h:61
DDMaterial::FractionV::value_type DDMaterial::constituent ( int  i) const

returns the i-th compound material and its fraction-mass

Definition at line 74 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::rep().

Referenced by OutputMagneticFieldDDToDDL::addToMatStore(), OutputDDToDDL::addToMatStore(), DDG4Builder::convertMaterial(), TGeoMgrFromDdd::createMaterial(), DDCheckMaterial(), DDHtmlMaDetails::details(), and DDCoreToDDXMLOutput::material().

74 { return rep().constituent(i); }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Material > >::reference rep() const
Definition: DDBase.h:65
double DDMaterial::density ( ) const

returns the density

Definition at line 80 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::rep().

Referenced by DDG4Builder::convertMaterial(), TGeoMgrFromDdd::createMaterial(), DDCheckMaterial(), DDHtmlMaDetails::details(), and DDCoreToDDXMLOutput::material().

80 { return rep().density(); }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Material > >::reference rep() const
Definition: DDBase.h:65
int DDMaterial::noOfConstituents ( ) const

returns the number of compound materials or 0 for elementary materials

Definition at line 72 of file DDMaterial.cc.

References DDBase< DDName, std::unique_ptr< DDI::Material > >::rep().

Referenced by OutputMagneticFieldDDToDDL::addToMatStore(), OutputDDToDDL::addToMatStore(), DDG4Builder::convertMaterial(), TGeoMgrFromDdd::createMaterial(), DDCheckMaterial(), DDHtmlMaDetails::details(), and DDCoreToDDXMLOutput::material().

72 { return rep().noOfConstituents(); }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Material > >::reference rep() const
Definition: DDBase.h:65
double DDMaterial::z ( ) const

Friends And Related Function Documentation

std::ostream& operator<< ( std::ostream &  os,
const DDMaterial mat 
)
friend

Definition at line 101 of file DDMaterial.cc.

101 { return doStream(os, mat, 0); }