xc
Reflection.h
1 // -*-c++-*-
2 //----------------------------------------------------------------------------
3 // XC program; finite element analysis code
4 // for structural analysis and design.
5 //
6 // Copyright (C) Luis C. Pérez Tato
7 //
8 // This program derives from OpenSees <http://opensees.berkeley.edu>
9 // developed by the «Pacific earthquake engineering research center».
10 //
11 // Except for the restrictions that may arise from the copyright
12 // of the original program (see copyright_opensees.txt)
13 // XC is free software: you can redistribute it and/or modify
14 // it under the terms of the GNU General Public License as published by
15 // the Free Software Foundation, either version 3 of the License, or
16 // (at your option) any later version.
17 //
18 // This software is distributed in the hope that it will be useful, but
19 // WITHOUT ANY WARRANTY; without even the implied warranty of
20 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 // GNU General Public License for more details.
22 //
23 //
24 // You should have received a copy of the GNU General Public License
25 // along with this program.
26 // If not, see <http://www.gnu.org/licenses/>.
27 //----------------------------------------------------------------------------
28 //Reflection.h
29 
30 #ifndef REFLECTION_H
31 #define REFLECTION_H
32 
33 #include "TrfGeom.h"
34 #include "utility/geom/trf/Reflection3d.h"
35 
36 namespace XC {
37 
41 class Reflection: public TrfGeom
42  {
43  Reflection3d rf;
44  public:
47  : TrfGeom(), rf(tr) {}
48  void setPlane(const Plane &p)
49  { rf= Reflection3d(p); }
50  virtual Pos3d Transform(const Pos3d &p) const;
51  virtual Vector3d Transform(const Vector3d &v) const;
52  };
53 } //end of XC namespace
54 
55 #endif
Reflection(const Reflection3d &tr=Reflection3d())
Constructor.
Definition: Reflection.h:46
Plane in a three-dimensional space.
Definition: Plane.h:49
Reflexión en 3d.
Definition: Reflection3d.h:35
Reflection transformation.
Definition: Reflection.h:41
Geometric transformation that can be applied to the components of a set.
Definition: TrfGeom.h:48
virtual Pos3d Transform(const Pos3d &p) const
Applies the transformation to the elements of the set.
Definition: Reflection.cc:40
Posición en tres dimensiones.
Definition: Pos3d.h:44
Open source finite element program for structural analysis.
Definition: ContinuaReprComponent.h:35
Vector en tres dimensiones.
Definition: Vector3d.h:39