CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
PseudoTrap.h
Go to the documentation of this file.
1 #ifndef DDI_PseudoTrap_h
2 #define DDI_PseudoTrap_h
3 
4 #include <iostream>
5 #include <vector>
6 
8 #include "Solid.h"
9 
10 namespace DDI {
11 
12  class PseudoTrap : public Solid {
13  public:
14  PseudoTrap(double x1, double x2, double y1, double y2, double z, double radius, bool minusZ)
16  p_.emplace_back(x1);
17  p_.emplace_back(x2);
18  p_.emplace_back(y1);
19  p_.emplace_back(y2);
20  p_.emplace_back(z);
21  p_.emplace_back(radius);
22  p_.emplace_back(minusZ);
23  }
24 
25  ~PseudoTrap() override {}
26 
27  double volume() const override { return -1; }
28 
29  void stream(std::ostream& os) const override;
30  };
31 
32 } // namespace DDI
33 
34 #endif // DDI_PseudoTrap_h
double volume() const override
Definition: PseudoTrap.h:27
void stream(std::ostream &os) const override
Definition: PseudoTrap.cc:6
PseudoTrap(double x1, double x2, double y1, double y2, double z, double radius, bool minusZ)
Definition: PseudoTrap.h:14
~PseudoTrap() override
Definition: PseudoTrap.h:25
DDSolidShape
Definition: DDSolidShapes.h:6
std::vector< double > p_
Definition: Solid.h:30