File indexing completed on 2025-01-18 10:01:25
0001
0002 #include <math.h>
0003
0004 #include <TObject.h>
0005 #include <TVector3.h>
0006
0007 #ifndef _IRT_PARAMETRIC_SURFACE_
0008 #define _IRT_PARAMETRIC_SURFACE_
0009
0010 class ParametricSurface: public TObject {
0011 public:
0012 ParametricSurface(): m_Umin(0.0), m_Umax(0.0), m_Vmin(0.0), m_Vmax(0.0) {};
0013 ParametricSurface(const TVector3 &x0, double umin, double umax, double vmin, double vmax):
0014 m_Center(x0), m_Umin(umin), m_Umax(umax), m_Vmin(vmin), m_Vmax(vmax) {};
0015 ~ParametricSurface() {};
0016
0017
0018 double Umin( void ) const { return m_Umin; };
0019 double Umax( void ) const { return m_Umax; };
0020 double Vmin( void ) const { return m_Vmin; };
0021 double Vmax( void ) const { return m_Vmax; };
0022 bool IsInside(double u, double v) const {
0023 return (u >= m_Umin && u <= m_Umax && v >= m_Vmin && v <= m_Vmax);
0024 };
0025 void SetUVranges(double umin, double umax, double vmin, double vmax) {
0026 m_Umin = umin; m_Umax = umax; m_Vmin = vmin; m_Vmax = vmax;
0027 };
0028
0029 virtual TVector3 GetSpacePoint(double u, double v) const = 0;
0030
0031
0032
0033
0034
0035 virtual TVector3 GetNormal(const TVector3 &xx) const = 0;
0036
0037
0038 virtual TVector3 GetNormal(double u, double v) const {
0039 auto pt = GetSpacePoint(u, v);
0040 return GetNormal(pt);
0041 };
0042
0043 virtual TVector3 GetNormal( void ) const {
0044 return TVector3(0.0, 0.0, 0.0);
0045 };
0046 const TVector3 &GetCenter( void ) const { return m_Center; };
0047 virtual double GetDistance(const TVector3 &xx) const = 0;
0048
0049
0050 virtual bool GetCrossing(const TVector3 &x0, const TVector3 &n0, TVector3 *crs,
0051 bool check_normal = true) const = 0;
0052
0053
0054 virtual ParametricSurface *_Clone(double angle, const TVector3 &axis) const = 0;
0055 void Shift(const TVector3 &shift) {
0056 m_Center += shift;
0057 };
0058
0059 protected:
0060
0061 TVector3 m_Center;
0062
0063 private:
0064 double m_Umin, m_Umax, m_Vmin, m_Vmax;
0065
0066 #ifndef DISABLE_ROOT_IO
0067 ClassDef(ParametricSurface, 1);
0068 #endif
0069 };
0070
0071 class SphericalSurface: public ParametricSurface {
0072 public:
0073 SphericalSurface(): m_Concave(true), m_Radius(0.0) {};
0074 SphericalSurface(const TVector3 &x0, double r0, double umin = 0.0, double umax = M_PI,
0075 double vmin = 0.0, double vmax = 2*M_PI):
0076 ParametricSurface(x0, umin, umax, vmin, vmax), m_Concave(true), m_Radius(r0) {};
0077 ~SphericalSurface() {};
0078
0079
0080 TVector3 GetSpacePoint(double theta, double phi) const {
0081 TVector3 nn(sin(theta)*cos(phi), sin(theta)*sin(phi), cos(theta));
0082 return GetCenter() + m_Radius*nn;
0083 };
0084
0085 TVector3 GetNormal(const TVector3 &xx) const {
0086 return (m_Concave ? -1.0 : 1.0)*(xx - GetCenter()).Unit();
0087 };
0088 double GetRadius( void ) const { return m_Radius; };
0089
0090 bool GetCrossing(const TVector3 &x0, const TVector3 &n0, TVector3 *crs, bool check_normal = true) const;
0091 double GetDistance(const TVector3 &xx) const;
0092
0093 void SetConvex( void ) { m_Concave = false; };
0094 ParametricSurface *_Clone(double angle, const TVector3 &axis) const {
0095 auto copy = new SphericalSurface(*this);
0096
0097 copy->m_Center.Rotate(angle, axis);
0098
0099 return copy;
0100 };
0101
0102 private:
0103 bool m_Concave;
0104 double m_Radius;
0105
0106 #ifndef DISABLE_ROOT_IO
0107 ClassDef(SphericalSurface, 2);
0108 #endif
0109 };
0110
0111 class LocalCoordinatesXY: public TObject {
0112 public:
0113 LocalCoordinatesXY() {};
0114 ~LocalCoordinatesXY() {};
0115
0116 virtual double GetLocalX(const TVector3 &xx) const = 0;
0117 virtual double GetLocalY(const TVector3 &xx) const = 0;
0118
0119 #ifndef DISABLE_ROOT_IO
0120 ClassDef(LocalCoordinatesXY, 1);
0121 #endif
0122 };
0123
0124
0125 class FlatSurface: public ParametricSurface, public LocalCoordinatesXY {
0126 public:
0127 FlatSurface() {};
0128 FlatSurface(const TVector3 &x0, const TVector3 &nx, const TVector3 &ny, double sx = 0.0, double sy = 0.0):
0129
0130 ParametricSurface(x0, -sx/2, sx/2, -sy/2, sy/2), m_Nx(nx.Unit()), m_Ny(ny.Unit()) {
0131 m_Nz = nx.Cross(ny).Unit();
0132 };
0133 ~FlatSurface() {};
0134
0135 TVector3 GetSpacePoint(double x, double y) const {
0136 return GetCenter() + x*m_Nx + y*m_Ny;
0137 };
0138 TVector3 GetNormal(const TVector3 &xx) const {
0139
0140 return m_Nz + 0.0*xx;
0141 };
0142 TVector3 GetNormal( void ) const {
0143 return m_Nz;
0144 };
0145
0146 inline double GetLocalX(const TVector3 &xx) const {
0147 return (xx - GetCenter()).Dot(m_Nx);
0148 };
0149 inline double GetLocalY(const TVector3 &xx) const {
0150 return (xx - GetCenter()).Dot(m_Ny);
0151 };
0152
0153 bool GetCrossing(const TVector3 &x0, const TVector3 &n0, TVector3 *crs, bool check_normal = true) const;
0154 double GetDistance(const TVector3 &xx) const;
0155 ParametricSurface *_Clone(double angle, const TVector3 &axis) const {
0156 auto copy = new FlatSurface(*this);
0157
0158 copy->m_Center.Rotate(angle, axis);
0159
0160 copy->m_Nx.Rotate(angle, axis);
0161 copy->m_Ny.Rotate(angle, axis);
0162 copy->m_Nz.Rotate(angle, axis);
0163
0164 return copy;
0165 };
0166
0167 private:
0168 TVector3 m_Nx, m_Ny, m_Nz;
0169
0170 #ifndef DISABLE_ROOT_IO
0171 ClassDef(FlatSurface, 1);
0172 #endif
0173 };
0174
0175 #endif