Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / mesh / extrudeModel / wedge / wedge.H
blob78bfb3667316e4953dca23b0e14c6cb26749c48d
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation, either version 3 of the License, or (at your
14     option) any later version.
16     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     Foam::extrudeModels::wedge
27 Description
28     Extrudes by rotating a surface around an axis
29     - extrusion is opposite the surface/patch normal so inwards the source
30       mesh
31     - axis direction has to be consistent with this.
32     - use -mergeFaces option if doing full 360 and want to merge front and back
33     - note direction of axis. This should be consistent with rotating against
34       the patch normal direction. If you get it wrong you'll see all cells
35       with extreme aspect ratio and internal faces wrong way around in
36       checkMesh
38 \*---------------------------------------------------------------------------*/
40 #ifndef wedge_H
41 #define wedge_H
43 #include "extrudeModel.H"
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47 namespace Foam
49 namespace extrudeModels
52 /*---------------------------------------------------------------------------*\
53                          Class wedge Declaration
54 \*---------------------------------------------------------------------------*/
56 class wedge
58     public extrudeModel
60     // Private data
62         //- Point on axis
63         const point axisPt_;
65         //- Normalized direction of axis
66         const vector axis_;
68         //- Overall angle (radians)
69         const scalar angle_;
72 public:
74     //- Runtime type information
75     TypeName("wedge");
77     // Constructors
79         //- Construct from components
80         wedge(const dictionary& dict);
83     //- Destrcuctor
84     ~wedge();
87     // Member Operators
89         point operator()
90         (
91             const point& surfacePoint,
92             const vector& surfaceNormal,
93             const label layer
94         ) const;
98 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
100 } // End namespace extrudeModels
101 } // End namespace Foam
103 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
105 #endif
107 // ************************************************************************* //