VCSMapping.h 6.8 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
///////////////////////////////////////////////////////////////////////////////
//
// File VCSMapping.h
//
// For more information, please see: http://www.nektar.info
//
// The MIT License
//
// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
// Department of Aeronautics, Imperial College London (UK), and Scientific
// Computing and Imaging Institute, University of Utah (USA).
//
// License for the specific language governing rights and limitations under
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
// Description: Velocity Correction Scheme with coordinate transformation header 
//
///////////////////////////////////////////////////////////////////////////////

#ifndef NEKTAR_SOLVERS_VCSMAPPING_H
#define NEKTAR_SOLVERS_VCSMAPPING_H

#include <IncNavierStokesSolver/EquationSystems/VelocityCorrectionScheme.h>
40
#include <GlobalMapping/Mapping.h>
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66

namespace Nektar
{
    class VCSMapping: public VelocityCorrectionScheme
    {
    public:

        /// Creates an instance of this class
        static SolverUtils::EquationSystemSharedPtr create(
                const LibUtilities::SessionReaderSharedPtr& pSession) {
            SolverUtils::EquationSystemSharedPtr p =
                                MemoryManager<VCSMapping>::
                                            AllocateSharedPtr(pSession);
            p->InitObject();
            return p;
        }

        /// Name of class
        static std::string className;


        /// Constructor.
        VCSMapping(const LibUtilities::SessionReaderSharedPtr& pSession);
        
        // 
        void ApplyIncNSMappingForcing (
67
                const Array<OneD, Array<OneD, NekDouble> >        &inarray,
68
69
70
71
72
73
74
75
                Array<OneD, Array<OneD, NekDouble> >              &outarray);

        virtual ~VCSMapping();

        virtual void v_InitObject();

    protected:
        // Mapping object
Douglas Serson's avatar
Douglas Serson committed
76
        GlobalMapping::MappingSharedPtr             m_mapping;
77
78
        
        bool                                        m_verbose;
79
        
80
81
        // Flags defining how pressure and viscous mapping terms 
        //should be treated
82
83
        bool                                        m_implicitPressure;
        bool                                        m_implicitViscous;
84
        bool                                        m_neglectViscous;
85
86
87
88
89
90
91
        // Tolerance and relaxation parameters for pressure and viscous
        //       systems (when solved iteratively)
        NekDouble                                   m_pressureTolerance;
        NekDouble                                   m_viscousTolerance;
        NekDouble                                   m_pressureRelaxation;
        NekDouble                                   m_viscousRelaxation;
        
92
93
94
        // Pressure gradient (to avoid duplicate calculations)
        Array<OneD, Array<OneD, NekDouble> >        m_gradP;

95
96
97
98
        // Virtual functions     
        virtual void v_DoInitialise(void);
        
        
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
        virtual void v_SetUpPressureForcing(
                    const Array<OneD, const Array<OneD, NekDouble> > &fields,
                    Array<OneD, Array<OneD, NekDouble> > &Forcing,
                    const NekDouble aii_Dt);
        
        virtual void v_SetUpViscousForcing(
                    const Array<OneD, const Array<OneD, NekDouble> > &inarray,
                    Array<OneD, Array<OneD, NekDouble> > &Forcing,
                    const NekDouble aii_Dt);
        
        virtual void v_SolvePressure( const Array<OneD, NekDouble>  &Forcing);
        
        virtual void v_SolveViscous( 
                    const Array<OneD, const Array<OneD, NekDouble> > &Forcing,
                    Array<OneD, Array<OneD, NekDouble> > &outarray,
                    const NekDouble aii_Dt);
        
        virtual void v_EvaluateAdvection_SetPressureBCs(
                    const Array<OneD, const Array<OneD, NekDouble> > &inarray,
                    Array<OneD, Array<OneD, NekDouble> > &outarray,
                    const NekDouble time);
    
121
122
    private:        
        Array<OneD, Array<OneD, NekDouble> >    m_presForcingCorrection;
123
        
124
        // Correction needed for convective terms = N(u) - ( -(u \nabla) u)
125
        //     velPhys is the velocity field (transformed for physical space)
126
        void MappingAdvectionCorrection(
127
            const Array<OneD, Array<OneD, NekDouble> >        &velPhys,
128
129
130
131
            Array<OneD, Array<OneD, NekDouble> >              &outarray);

        // Correction needed for time-derivative terms 
        //     = U_coord^j u^i_,j - u^j U_coord^i_,j
132
133
        //     vel     is the velocity field (can be in wavespace)
        //     velPhys is the velocity field (transformed for physical space)
134
        void MappingAccelerationCorrection(
135
136
            const Array<OneD, Array<OneD, NekDouble> >        &vel,
            const Array<OneD, Array<OneD, NekDouble> >        &velPhys,
137
138
139
140
141
            Array<OneD, Array<OneD, NekDouble> >              &outarray);

        // Correction needed for pressure terms   
        //     = -g^(ij)p_j + (\nabla p)/J for variable Jacobian
        //     = -g^(ij)p_j + (\nabla p)   for constant Jacobian
142
        //         the pressure field can be in wavespace
143
144
145
146
        void MappingPressureCorrection(
            Array<OneD, Array<OneD, NekDouble> >              &outarray);

        // Correction needed for viscous terms = g^jk u^i_{,jk}-(\nabla^2 u)
147
148
        //     vel     is the velocity field (can be in wavespace)
        //     velPhys is the velocity field (transformed for physical space)
149
        void MappingViscousCorrection(
150
            const Array<OneD, Array<OneD, NekDouble> >        &velPhys,
151
152
            Array<OneD, Array<OneD, NekDouble> >              &outarray);
        
153
154
155
156
157
158
159
160
161
    };

    typedef boost::shared_ptr<VCSMapping>
                VCSMappingSharedPtr;

} //end of namespace


#endif //VELOCITY_CORRECTION_SCHEME_H