source: flexpart.git/src/wetdepokernel_nest.f90 @ 7999df47

10.4.1_peseiGFS_025bugfixes+enhancementsdevrelease-10release-10.4.1scaling-bugunivie
Last change on this file since 7999df47 was db712a8, checked in by Espen Sollum ATMOS <eso@…>, 8 years ago

Completed handling of nested wind fields with cloud water (for wet deposition).

  • Property mode set to 100644
File size: 5.3 KB
Line 
1!**********************************************************************
2! Copyright 1998,1999,2000,2001,2002,2005,2007,2008,2009,2010         *
3! Andreas Stohl, Petra Seibert, A. Frank, Gerhard Wotawa,             *
4! Caroline Forster, Sabine Eckhardt, John Burkhart, Harald Sodemann   *
5!                                                                     *
6! This file is part of FLEXPART.                                      *
7!                                                                     *
8! FLEXPART is free software: you can redistribute it and/or modify    *
9! it under the terms of the GNU General Public License as published by*
10! the Free Software Foundation, either version 3 of the License, or   *
11! (at your option) any later version.                                 *
12!                                                                     *
13! FLEXPART is distributed in the hope that it will be useful,         *
14! but WITHOUT ANY WARRANTY; without even the implied warranty of      *
15! MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the       *
16! GNU General Public License for more details.                        *
17!                                                                     *
18! You should have received a copy of the GNU General Public License   *
19! along with FLEXPART.  If not, see <http://www.gnu.org/licenses/>.   *
20!**********************************************************************
21
22subroutine wetdepokernel_nest(nunc,deposit,x,y,nage,kp)
23  !                           i    i       i i i    i
24  !*****************************************************************************
25  !                                                                            *
26  !     Attribution of the deposition from an individual particle to the       *
27  !     nested deposition fields using a uniform kernel with bandwidths        *
28  !     dxoutn and dyoutn.                                                     *
29  !                                                                            *
30  !     Author: A. Stohl                                                       *
31  !                                                                            *
32  !     26 December 1996                                                       *
33  !                                                                            *
34  !      2 September 2004: Adaptation from wetdepokernel.                      *
35  !                                                                            *
36  !                                                                            *
37  !*****************************************************************************
38  !                                                                            *
39  ! Variables:                                                                 *
40  !                                                                            *
41  ! nunc             uncertainty class of the respective particle              *
42  ! nage             age class of the respective particle                      *
43  ! deposit          amount (kg) to be deposited                               *
44  !                                                                            *
45  !*****************************************************************************
46
47  use unc_mod
48  use par_mod
49  use com_mod
50
51  implicit none
52
53  real :: x,y,deposit(maxspec),ddx,ddy,xl,yl,wx,wy,w
54  integer :: ix,jy,ixp,jyp,ks,kp,nunc,nage
55
56  real :: dbg_dx, dbg_dy, dbg_xoutshiftn, dbg_youtshiftn, dbg_dxoutn, dbg_dyoutn,dbg_t
57
58  xl=(x*dx+xoutshiftn)/dxoutn
59  yl=(y*dy+youtshiftn)/dyoutn
60
61  ! old:
62  ! ix=int(xl)
63  ! jy=int(yl)
64
65  ! ESO: for xl,yl in range <-.5,-1> we get ix,jy=0 and thus negative
66  ! wx,wy as the int function rounds upwards for negative numbers.
67  ! Either use the floor function, or (perhaps more correctly?) use "(xl.gt.-0.5)"
68  ! in place of "(ix.ge.0)" and similar for the upper boundary.
69
70  ! new:
71  ix=floor(xl)
72  jy=floor(yl)
73
74  ddx=xl-real(ix)                   ! distance to left cell border
75  ddy=yl-real(jy)                   ! distance to lower cell border
76
77
78  if (ddx.gt.0.5) then
79    ixp=ix+1
80    wx=1.5-ddx
81  else
82    ixp=ix-1
83    wx=0.5+ddx
84  endif
85
86  if (ddy.gt.0.5) then
87    jyp=jy+1
88    wy=1.5-ddy
89  else
90    jyp=jy-1
91    wy=0.5+ddy
92  endif
93
94! Determine mass fractions for four grid points
95!**********************************************
96
97  do ks=1,nspec
98    if ((ix.ge.0).and.(jy.ge.0).and.(ix.le.numxgridn-1).and. &
99         (jy.le.numygridn-1)) then
100      w=wx*wy
101      wetgriduncn(ix,jy,ks,kp,nunc,nage)= &
102           wetgriduncn(ix,jy,ks,kp,nunc,nage)+deposit(ks)*w
103    endif
104
105    if ((ixp.ge.0).and.(jyp.ge.0).and.(ixp.le.numxgridn-1).and. &
106         (jyp.le.numygridn-1)) then
107      w=(1.-wx)*(1.-wy)
108      wetgriduncn(ixp,jyp,ks,kp,nunc,nage)= &
109           wetgriduncn(ixp,jyp,ks,kp,nunc,nage)+deposit(ks)*w
110    endif
111
112    if ((ixp.ge.0).and.(jy.ge.0).and.(ixp.le.numxgridn-1).and. &
113         (jy.le.numygridn-1)) then
114      w=(1.-wx)*wy
115      wetgriduncn(ixp,jy,ks,kp,nunc,nage)= &
116           wetgriduncn(ixp,jy,ks,kp,nunc,nage)+deposit(ks)*w
117    endif
118
119    if ((ix.ge.0).and.(jyp.ge.0).and.(ix.le.numxgridn-1).and. &
120         (jyp.le.numygridn-1)) then
121      w=wx*(1.-wy)
122      wetgriduncn(ix,jyp,ks,kp,nunc,nage)= &
123           wetgriduncn(ix,jyp,ks,kp,nunc,nage)+deposit(ks)*w
124    endif
125
126  end do
127end subroutine wetdepokernel_nest
Note: See TracBrowser for help on using the repository browser.
hosted by ZAMG