[Nek5000-users] Clarification on Adjoint solver
nek5000-users at lists.mcs.anl.gov
nek5000-users at lists.mcs.anl.gov
Fri Feb 5 14:15:42 CST 2016
Adams,
I really appreciate your detailed answer. I definitely clarified the Nek
functionality for adjoint solvers. One question remains is how to
include the velocity of the forward solver into adjoint equations. I
assume this is also the case when you do linear stability analysis with
Nek, since the velocity in convective terms is not completely part of
the solution. Mathematically, my question is:
in $V. \nabla u_a$ term, as the advection, how can we substitute $V$ (as
the forward velocity which is already solved for in a regular NS
solution) in adjoint equations. suppose that the velocity, along with
other quantities are saved in afield out put such as fld.f0000X for X
time-step. So we have access to that velocity but how can we include it
in adjoint equations?
Many thanks again,
Saleh
On 2/2/2016 3:09 AM, nek5000-users at lists.mcs.anl.gov wrote:
> Hi
>
> The adjoint implementation in nek assumes change of the direction of
> time evolution. The goal is to use the standard nek solver with
> minimal modifications (only advection terms have to be changed). You
> get these equations from you standard one by changing the time and
> pressure sign (t -> -t; p-> -p). This of course changes your time
> integration limits, but it shouldn't be a problem. So when you have
> your linear direct simulation, to turn it into dual one it is enough
> to include in your userchk include files ADJOINT and TSTEP, and for
> ISTEP.eq.0 set IFADJOINT to true. Something like:
> subroutine userchk
>
> include 'SIZE'
> include 'TSTEP' ! ISTEP
> include 'ADJOINT' ! IFADJ
>
> if(ISTEP.eq.0) ADJOINT=.TRUE.
>
> There is no need to modify ###.rea or ###.map files. The only problem
> are boundary conditions for open flows, as they would require
> non-homogeneous bc. In this case to avoid problems we usually use
> sufficiently large domain together with zero Dirichlet bc. The last
> issue is sufficient resolution for both direct and adjoin runs. I hope
> this gives you some idea about nek implementation.
> Regards
> Adam
>
> On 2016-02-01 22:17, nek5000-users at lists.mcs.anl.gov wrote:
>> Hi Neks,
>>
>> To my knowledge, Nek5000 is able to solve adjoint equations of the form:
>> $\partial u_a/\partial t + V.\nabla u_a - u_a.(\nabla V)^T + \nabla
>> \p_a + 1/Re \nabla^2 u_a=0$ and $\nabla.u_a=0$
>> where u_a and p_a are adjoint velocity and pressure. (Slightly
>> different formulation may be seen in literature).
>>
>> Let's assume the forward problem is already solved so that $V$, i.e.
>> velocity, (and possibly $p$ as the pressure) is (are) already know.
>> Thus, the initial and boundary conditions for adjoint NS are also
>> known. How can we now solve the dual/adjoint NS problem with Nek5000?
>> Is there any example on how to modify .rea files? Specailly, the
>> "convection term of $V.\nabla u_a - u_a.(\nabla V)^T$ needs to be
>> modified compared to forward NS but am not sure how.
>> My search of mailing list entails some modifications in "perturb.f"
>> subroutine, but a little bit more clarification on that would be
>> really appreciated.
>>
>> Yours,
>> Saleh
>> _______________________________________________
>> Nek5000-users mailing list
>> Nek5000-users at lists.mcs.anl.gov
>> https://lists.mcs.anl.gov/mailman/listinfo/nek5000-users
>
> _______________________________________________
> Nek5000-users mailing list
> Nek5000-users at lists.mcs.anl.gov
> https://lists.mcs.anl.gov/mailman/listinfo/nek5000-users
More information about the Nek5000-users
mailing list