source: LMDZ6/branches/cirrus/libf/phylmd/inlandsis/sisvat_bsn.F @ 5447

Last change on this file since 5447 was 3900, checked in by evignon, 4 years ago

Commission de la nouvelle interface LMDZ-SISVAT
la prochaine commission consistera a supprimer l'ancien repertoire sisvat
et a faire un peu de nettoyage.

File size: 3.6 KB
Line 
1 
2 
3      subroutine SISVAT_BSn
4 
5C +------------------------------------------------------------------------+
6C | MAR          SISVAT_BSn                               04-apr-2020  MAR |
7C |   SubRoutine SISVAT_BSn treats Snow Erosion                            |
8C |   (not deposition anymore since 2-jun 2018)                            |
9C |                                                                        |
10C |   SISVAT_bsn computes the snow erosion mass according to both the      |
11C |   theoretical maximum erosion amount computed in inlandsis and the     |
12C |   availability of snow (currently in the uppermost snow layer only)    |
13C |                                                                        |
14C +------------------------------------------------------------------------+
15 
16 
17 
18 
19C +--General Variables
20C +  =================
21
22      use VARphy
23      use VAR_SV
24      use VARdSV
25      use VARxSV
26      use VARySV
27 
28 
29       IMPLICIT NONE
30
31C +--Local Variables
32C +  ===============
33 
34 
35      integer  ikl   ,isn
36      real     h_mmWE                        ! Eroded Snow Layer Min Thickness
37      real     dbsaux(knonv)                 ! Drift Amount   (Dummy Variable)
38      real     dzweqo,dzweqn,bsno_x          ! Conversion variables for erosion
39      real     dz_new,rho_new
40      real     snofOK                        ! Threshd Snow Fall
41      real     Fac                           ! Correction factor for erosion
42      real     densif                        ! Densification rate if erosion
43 
44C +--DATA
45C +  ====
46 
47      data     h_mmWE  / 0.01e00  /          ! Eroded Snow Layer Min Thickness
48 
49C +--EROSION
50C +  =======
51 
52      !DO isn = nsno,2,-1
53      DO ikl = 1,knonv
54 
55        isn         = isnoSV(ikl)
56        dzweqo      = dzsnSV(ikl,isn) *ro__SV(ikl,isn)      ! [kg/m2, mm w.e.]
57 
58        bsno_x      = min(0.,dbs_SV(ikl))
59c       Fac         = min(1.,max(1-(ro__SV(ikl,isn)/700.),0.)**2)
60c       Fac         = min(1.,max(1-(qsnoSV(ikl)*1000/30.),0.))
61c       bsno_x      = bsno_x*Fac
62 
63        dzweqn      = dzweqo + bsno_x
64        dzweqn      = max(dzweqn,h_mmWE)
65        dzweqn      = min(dzweqn,dzweqo)
66cXF
67        dbs_SV(ikl) = dbs_SV(ikl)    +(dzweqo -dzweqn)
68        dbs_Er(ikl) = dbs_Er(ikl)    +(dzweqo -dzweqn)
69        dzsnSV(ikl,isn) =              dzweqn
70     .                       /max(epsi,ro__SV(ikl,isn))
71 
72        ! Densification of the uppermost snow layer if erosion:
73        if((dzweqo-dzweqn)>0                    .and.
74     .     dzsnSV(ikl,isn)>0                    .and.
75     .     ro__SV(ikl,max(1,isnoSV(ikl)))<roBdSV) then
76 
77        !characteristic time scale for drifting snow compaction set to 24h
78        !linear densification rate [kg/m3/s] over 24h
79        densif         = (450. - frsno) / (3600*24)
80 
81        !Attenuation of compaction rate from 450 to 500 kg/m3
82        Fac         = 1-((ro__SV(ikl,max(1,isnoSV(ikl)))
83     .                        -roBdSV)/(500.-roBdSV))
84        Fac         = max(0.,min(1.,Fac))
85 
86        if (ro__SV(ikl,max(1,isnoSV(ikl)))>roBdSV) then
87          densif=densif*Fac
88        endif
89 
90        rho_new        = min(roBdSV,ro__SV(ikl,isn)+densif*dt__SV)
91        dz_new         = dzsnSV(ikl,isn)*ro__SV(ikl,isn)/rho_new
92        ro__SV(ikl,isn)=rho_new
93        dzsnSV(ikl,isn)=dz_new
94        endif
95 
96        if(dzsnSV(ikl,isn)>0 .and.dzsnSV(ikl,isn)<0.0001)then
97        dbs_SV(ikl) = dbs_SV(ikl)+ dzsnSV(ikl,isn)*ro__SV(ikl,isn)
98        dbs_Er(ikl) = dbs_Er(ikl)+ dzsnSV(ikl,isn)*ro__SV(ikl,isn)
99        dzsnSV(ikl,isn) = 0
100        ro__SV(ikl,isn) = 0
101        isnoSV(ikl)     = max(0,isnoSV(ikl) - 1)
102        endif
103 
104      END DO
105      !END DO
106 
107      return
108      END
Note: See TracBrowser for help on using the repository browser.