FreeFOAM The Cross-Platform CFD Toolkit
Hosted by SourceForge:
Get FreeFOAM at SourceForge.net.
            Fast, secure and Free Open Source software downloads

pressureInletOutletVelocityFvPatchVectorField.H

Go to the documentation of this file.
00001 /*---------------------------------------------------------------------------*\
00002   =========                 |
00003   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
00004    \\    /   O peration     |
00005     \\  /    A nd           | Copyright (C) 1991-2010 OpenCFD Ltd.
00006      \\/     M anipulation  |
00007 -------------------------------------------------------------------------------
00008 License
00009     This file is part of OpenFOAM.
00010 
00011     OpenFOAM is free software: you can redistribute it and/or modify it
00012     under the terms of the GNU General Public License as published by
00013     the Free Software Foundation, either version 3 of the License, or
00014     (at your option) any later version.
00015 
00016     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
00017     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
00018     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
00019     for more details.
00020 
00021     You should have received a copy of the GNU General Public License
00022     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
00023 
00024 Class
00025     Foam::pressureInletOutletVelocityFvPatchVectorField
00026 
00027 Description
00028     Velocity inlet/outlet boundary condition patches for where the pressure is
00029     specified.  zero-gradient is applied for outflow (as defined by the flux)
00030     and for inflow the velocity is obtained from the patch-face normal
00031     component of the internal-cell value.
00032 
00033 SourceFiles
00034     pressureInletOutletVelocityFvPatchVectorField.C
00035 
00036 \*---------------------------------------------------------------------------*/
00037 
00038 #ifndef pressureInletOutletVelocityFvPatchVectorField_H
00039 #define pressureInletOutletVelocityFvPatchVectorField_H
00040 
00041 #include <finiteVolume/fvPatchFields.H>
00042 #include <finiteVolume/directionMixedFvPatchFields.H>
00043 
00044 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00045 
00046 namespace Foam
00047 {
00048 
00049 /*---------------------------------------------------------------------------*\
00050               Class pressureInletOutletVelocityFvPatch Declaration
00051 \*---------------------------------------------------------------------------*/
00052 
00053 class pressureInletOutletVelocityFvPatchVectorField
00054 :
00055     public directionMixedFvPatchVectorField
00056 {
00057     // Private data
00058 
00059         word phiName_;
00060 
00061         //- Optional tangential velocity component
00062         vectorField tangentialVelocity_;
00063 
00064 
00065 public:
00066 
00067     //- Runtime type information
00068     TypeName("pressureInletOutletVelocity");
00069 
00070 
00071     // Constructors
00072 
00073         //- Construct from patch and internal field
00074         pressureInletOutletVelocityFvPatchVectorField
00075         (
00076             const fvPatch&,
00077             const DimensionedField<vector, volMesh>&
00078         );
00079 
00080         //- Construct from patch, internal field and dictionary
00081         pressureInletOutletVelocityFvPatchVectorField
00082         (
00083             const fvPatch&,
00084             const DimensionedField<vector, volMesh>&,
00085             const dictionary&
00086         );
00087 
00088         //- Construct by mapping given
00089         //  pressureInletOutletVelocityFvPatchVectorField onto a new patch
00090         pressureInletOutletVelocityFvPatchVectorField
00091         (
00092             const pressureInletOutletVelocityFvPatchVectorField&,
00093             const fvPatch&,
00094             const DimensionedField<vector, volMesh>&,
00095             const fvPatchFieldMapper&
00096         );
00097 
00098         //- Construct as copy
00099         pressureInletOutletVelocityFvPatchVectorField
00100         (
00101             const pressureInletOutletVelocityFvPatchVectorField&
00102         );
00103 
00104         //- Construct and return a clone
00105         virtual tmp<fvPatchVectorField> clone() const
00106         {
00107             return tmp<fvPatchVectorField>
00108             (
00109                 new pressureInletOutletVelocityFvPatchVectorField(*this)
00110             );
00111         }
00112 
00113         //- Construct as copy setting internal field reference
00114         pressureInletOutletVelocityFvPatchVectorField
00115         (
00116             const pressureInletOutletVelocityFvPatchVectorField&,
00117             const DimensionedField<vector, volMesh>&
00118         );
00119 
00120         //- Construct and return a clone setting internal field reference
00121         virtual tmp<fvPatchVectorField> clone
00122         (
00123             const DimensionedField<vector, volMesh>& iF
00124         ) const
00125         {
00126             return tmp<fvPatchVectorField>
00127             (
00128                 new pressureInletOutletVelocityFvPatchVectorField(*this, iF)
00129             );
00130         }
00131 
00132 
00133     // Member functions
00134 
00135         // Access
00136 
00137             //- Return the name of phi
00138             const word& phiName() const
00139             {
00140                 return phiName_;
00141             }
00142 
00143             //- Return reference to the name of phi to allow adjustment
00144             word& phiName()
00145             {
00146                 return phiName_;
00147             }
00148 
00149             //- Return the tangential velocity
00150             const vectorField& tangentialVelocity() const
00151             {
00152                 return tangentialVelocity_;
00153             }
00154 
00155             //- Reset the tangential velocity
00156             void setTangentialVelocity(const vectorField& tangentialVelocity);
00157 
00158 
00159         // Mapping functions
00160 
00161             //- Map (and resize as needed) from self given a mapping object
00162             virtual void autoMap
00163             (
00164                 const fvPatchFieldMapper&
00165             );
00166 
00167             //- Reverse map the given fvPatchField onto this fvPatchField
00168             virtual void rmap
00169             (
00170                 const fvPatchVectorField&,
00171                 const labelList&
00172             );
00173 
00174 
00175         //- Update the coefficients associated with the patch field
00176         virtual void updateCoeffs();
00177 
00178         //- Write
00179         virtual void write(Ostream&) const;
00180 
00181 
00182     // Member operators
00183 
00184         virtual void operator=(const fvPatchField<vector>& pvf);
00185 };
00186 
00187 
00188 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00189 
00190 } // End namespace Foam
00191 
00192 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
00193 
00194 #endif
00195 
00196 // ************************ vim: set sw=4 sts=4 et: ************************ //
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines