VGM Version 5.3
Loading...
Searching...
No Matches
IPara.h
Go to the documentation of this file.
1// $Id$
2
3// -----------------------------------------------------------------------
4// The VGM package of the Virtual Geometry Model
5// Copyright (C) 2007, Ivana Hrivnacova
6// All rights reserved.
7//
8// For the licensing terms see vgm/LICENSE.
9// Contact: ivana@ipno.in2p3.fr
10// -----------------------------------------------------------------------
11
19
20#ifndef VGM_I_PARA_H
21#define VGM_I_PARA_H
22
23#include "VGM/solids/ISolid.h"
24
25#include <iostream>
26
27namespace VGM {
28
29class IPara : public virtual ISolid
30{
31 public:
32 virtual ~IPara() {}
33
34 // methods
35
36 virtual SolidType Type() const = 0;
37 virtual std::string Name() const = 0;
38
41 virtual double XHalfLength() const = 0;
44 virtual double YHalfLength() const = 0;
47 virtual double ZHalfLength() const = 0;
52 virtual double Alpha() const = 0;
56 virtual double Theta() const = 0;
60 virtual double Phi() const = 0;
61
62 // streaming
63 virtual std::ostream& Put(std::ostream& out) const = 0;
64};
65
66} // namespace VGM
67
68std::ostream& operator<<(std::ostream& out, const VGM::IPara& para);
69
70#endif // VGM_I_PARA_H
std::ostream & operator<<(std::ostream &out, const VGM::IPara &para)
Definition VPara.cxx:22
The VGM interface to para solids.
Definition IPara.h:30
virtual SolidType Type() const =0
Return the type of this solid.
virtual std::string Name() const =0
Return the name of this solid.
virtual std::ostream & Put(std::ostream &out) const =0
Put the printing of the solid parameters in the out stream.
virtual double Alpha() const =0
Return angle formed by the y axis and by the plane joining the centre of the faces parallel to the z-...
virtual double Theta() const =0
Return polar angle of the line joining the centres of the faces at -hz and +hz in deg.
virtual double YHalfLength() const =0
Return half-length along the y axis in mm.
virtual double ZHalfLength() const =0
Return half-length along the z axis in mm.
virtual double XHalfLength() const =0
Return half-length along the x axis in mm.
virtual double Phi() const =0
Return azimuthal angle of the line joining the centres of the faces at -hz and +hz in deg.
virtual ~IPara()
Definition IPara.h:32
The VGM interface to solids.
Definition ISolid.h:58
VGM interfaces.
Definition VMedium.h:28
SolidType
Definition ISolid.h:29