Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 11:56:00

0001 //   COCOA class header file

0002 //Id:  OptOModifiedRhomboidPrism.h

0003 //CAT: Model

0004 //

0005 //   Base class to describe Optical Objects of type sensor 2D

0006 //

0007 //   History: v1.0

0008 //   Pedro Arce

0009 
0010 #ifndef _OPTOMODIFIEDRHOMBOIDPRISM_HH
0011 #define _OPTOMODIFIEDRHOMBOIDPRISM_HH
0012 
0013 #include "Alignment/CocoaUtilities/interface/CocoaGlobals.h"
0014 #include "Alignment/CocoaModel/interface/OpticalObject.h"
0015 class Measurement;
0016 class LightRay;
0017 
0018 class OptOModifiedRhomboidPrism : public OpticalObject {
0019 public:
0020   //---------- Constructors / Destructor

0021   OptOModifiedRhomboidPrism(){};
0022   OptOModifiedRhomboidPrism(OpticalObject* parent, const ALIstring& type, const ALIstring& name, const ALIbool copy_data)
0023       : OpticalObject(parent, type, name, copy_data){};
0024   ~OptOModifiedRhomboidPrism() override{};
0025 
0026   //---------- Fast simulation of deviation of the light ray (reflection, shift, ...)

0027   void fastDeviatesLightRay(LightRay& lightray) override;
0028   //---------- Detailed simulation of the light ray traversing

0029   void fastTraversesLightRay(LightRay& lightray) override;
0030   //---------- Detailed simulation of deviation of the light ray (reflection, shift, ...)

0031   void detailedDeviatesLightRay(LightRay& lightray) override;
0032   //---------- Fast simulation of the light ray traversing

0033   void detailedTraversesLightRay(LightRay& lightray) override;
0034 
0035   //--------- Get the up and down plates rotated by an angle 'angle_planes'

0036   ALIPlane getRotatedPlate(const ALIbool forwardPlate);
0037 
0038 #ifdef COCOA_VIS
0039   virtual void fillIguana();
0040 #endif
0041   void constructSolidShape() override;
0042 };
0043 
0044 #endif