Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
G
GOSI9esm
Manage
Activity
Members
Code
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Locked files
Deploy
Releases
Package Registry
Model registry
Operate
Terraform modules
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Consortium Members
UKMO
GOSI
GOSI9esm
Commits
676a31ce
Commit
676a31ce
authored
2 years ago
by
Jérôme Chanut
Committed by
Guillaume Samson
2 years ago
Browse files
Options
Downloads
Patches
Plain Diff
Resolve "Issues with ssh initialization in iceinit with vvl and AGRIF"
parent
cabbd821
No related branches found
No related tags found
No related merge requests found
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
src/ICE/iceistate.F90
+3
-7
3 additions, 7 deletions
src/ICE/iceistate.F90
src/NST/agrif_oce_interp.F90
+19
-1
19 additions, 1 deletion
src/NST/agrif_oce_interp.F90
src/OCE/SBC/sbcdcy.F90
+2
-2
2 additions, 2 deletions
src/OCE/SBC/sbcdcy.F90
src/OCE/TRA/zpshde.F90
+3
-3
3 additions, 3 deletions
src/OCE/TRA/zpshde.F90
with
27 additions
and
13 deletions
src/ICE/iceistate.F90
+
3
−
7
View file @
676a31ce
...
@@ -436,11 +436,7 @@ CONTAINS
...
@@ -436,11 +436,7 @@ CONTAINS
! Override ssh adjustment in nested domains by the root-domain ssh adjustment;
! Override ssh adjustment in nested domains by the root-domain ssh adjustment;
! store the adjustment value in a global module variable to make it retrievable in nested domains
! store the adjustment value in a global module variable to make it retrievable in nested domains
IF
(
.NOT.
Agrif_Root
()
)
THEN
IF
(
.NOT.
Agrif_Root
()
)
THEN
IF
(
.NOT.
ln_init_chfrpar
)
THEN
! child is not initialized from the parent
zsshadj
=
Agrif_Parent
(
rsshadj
)
zsshadj
=
Agrif_Parent
(
rsshadj
)
ELSE
! child is initialized from the parent
zsshadj
=
0._wp
! => 0 since ssh adjustement is already done
ENDIF
ELSE
ELSE
rsshadj
=
zsshadj
rsshadj
=
zsshadj
ENDIF
ENDIF
...
@@ -463,10 +459,10 @@ CONTAINS
...
@@ -463,10 +459,10 @@ CONTAINS
#else
#else
DO
jk
=
1
,
jpk
DO
jk
=
1
,
jpk
DO_2D
(
nn_hls
,
nn_hls
,
nn_hls
,
nn_hls
)
DO_2D
(
nn_hls
,
nn_hls
,
nn_hls
,
nn_hls
)
IF
(
snwice_mass
(
ji
,
jj
)
/
=
0._wp
)
THEN
!
IF( snwice_mass(ji,jj) /= 0._wp ) THEN
e3t
(
ji
,
jj
,
jk
,
Kmm
)
=
e3t_0
(
ji
,
jj
,
jk
)
*
(
1._wp
+
ssh
(
ji
,
jj
,
Kmm
)
*
r1_ht_0
(
ji
,
jj
)
*
tmask
(
ji
,
jj
,
jk
)
)
e3t
(
ji
,
jj
,
jk
,
Kmm
)
=
e3t_0
(
ji
,
jj
,
jk
)
*
(
1._wp
+
ssh
(
ji
,
jj
,
Kmm
)
*
r1_ht_0
(
ji
,
jj
)
*
tmask
(
ji
,
jj
,
jk
)
)
e3t
(
ji
,
jj
,
jk
,
Kbb
)
=
e3t_0
(
ji
,
jj
,
jk
)
*
(
1._wp
+
ssh
(
ji
,
jj
,
Kbb
)
*
r1_ht_0
(
ji
,
jj
)
*
tmask
(
ji
,
jj
,
jk
)
)
e3t
(
ji
,
jj
,
jk
,
Kbb
)
=
e3t_0
(
ji
,
jj
,
jk
)
*
(
1._wp
+
ssh
(
ji
,
jj
,
Kbb
)
*
r1_ht_0
(
ji
,
jj
)
*
tmask
(
ji
,
jj
,
jk
)
)
ENDIF
!
ENDIF
END_2D
END_2D
END
DO
END
DO
!
!
...
...
This diff is collapsed.
Click to expand it.
src/NST/agrif_oce_interp.F90
+
19
−
1
View file @
676a31ce
...
@@ -34,7 +34,11 @@ MODULE agrif_oce_interp
...
@@ -34,7 +34,11 @@ MODULE agrif_oce_interp
USE
lib_mpp
USE
lib_mpp
USE
vremap
USE
vremap
USE
lbclnk
USE
lbclnk
#if defined key_si3
USE
iceistate
,
ONLY
:
rsshadj
,
nn_iceini_file
USE
sbc_oce
,
ONLY
:
ln_ice_embd
USE
sbc_ice
,
ONLY
:
snwice_mass
#endif
IMPLICIT
NONE
IMPLICIT
NONE
PRIVATE
PRIVATE
...
@@ -1108,7 +1112,21 @@ CONTAINS
...
@@ -1108,7 +1112,21 @@ CONTAINS
!!----------------------------------------------------------------------
!!----------------------------------------------------------------------
!
!
IF
(
before
)
THEN
IF
(
before
)
THEN
#if defined key_si3
IF
(
l_ini_child
.AND.
(
.NOT.
(
ln_rstart
.OR.
nn_iceini_file
==
2
)))
THEN
IF
(
ln_ice_embd
)
THEN
ptab
(
i1
:
i2
,
j1
:
j2
)
=
ssh
(
i1
:
i2
,
j1
:
j2
,
Kmm_a
)
&
&
+
snwice_mass
(
i1
:
i2
,
j1
:
j2
)
*
r1_rho0
ELSE
ptab
(
i1
:
i2
,
j1
:
j2
)
=
ssh
(
i1
:
i2
,
j1
:
j2
,
Kmm_a
)
&
&
+
rsshadj
*
tmask
(
i1
:
i2
,
j1
:
j2
,
1
)
ENDIF
ELSE
ptab
(
i1
:
i2
,
j1
:
j2
)
=
ssh
(
i1
:
i2
,
j1
:
j2
,
Kmm_a
)
ENDIF
#else
ptab
(
i1
:
i2
,
j1
:
j2
)
=
ssh
(
i1
:
i2
,
j1
:
j2
,
Kmm_a
)
ptab
(
i1
:
i2
,
j1
:
j2
)
=
ssh
(
i1
:
i2
,
j1
:
j2
,
Kmm_a
)
#endif
ELSE
ELSE
IF
(
l_ini_child
)
THEN
IF
(
l_ini_child
)
THEN
ssh
(
i1
:
i2
,
j1
:
j2
,
Krhs_a
)
=
ptab
(
i1
:
i2
,
j1
:
j2
)
*
tmask
(
i1
:
i2
,
j1
:
j2
,
1
)
ssh
(
i1
:
i2
,
j1
:
j2
,
Krhs_a
)
=
ptab
(
i1
:
i2
,
j1
:
j2
)
*
tmask
(
i1
:
i2
,
j1
:
j2
,
1
)
...
...
This diff is collapsed.
Click to expand it.
src/OCE/SBC/sbcdcy.F90
+
2
−
2
View file @
676a31ce
...
@@ -151,8 +151,8 @@ CONTAINS
...
@@ -151,8 +151,8 @@ CONTAINS
ENDIF
ENDIF
END_2D
END_2D
!
!
IF
(
PRESENT
(
l_mask
)
.AND.
l_mask
)
THEN
IF
(
PRESENT
(
l_mask
)
)
THEN
zqsrout
(:,:)
=
float
(
imask_night
(:,:))
IF
(
l_mask
)
zqsrout
(:,:)
=
float
(
imask_night
(:,:))
ENDIF
ENDIF
!
!
END
FUNCTION
sbc_dcy
END
FUNCTION
sbc_dcy
...
...
This diff is collapsed.
Click to expand it.
src/OCE/TRA/zpshde.F90
+
3
−
3
View file @
676a31ce
...
@@ -164,7 +164,7 @@ CONTAINS
...
@@ -164,7 +164,7 @@ CONTAINS
END_2D
END_2D
END
DO
END
DO
!
!
IF
(
nn_hls
==
1
)
CALL
lbc_lnk
(
'zpshde'
,
pgtu
(:,:,:)
,
'U'
,
-1.0_wp
,
pgtv
(:,:,:)
,
'V'
,
-1.0_wp
)
! Lateral boundary cond.
IF
(
nn_hls
==
1
)
CALL
lbc_lnk
(
'zpshde'
,
pgtu
,
'U'
,
-1.0_wp
,
pgtv
,
'V'
,
-1.0_wp
)
! Lateral boundary cond.
!
!
IF
(
PRESENT
(
prd
)
)
THEN
!== horizontal derivative of density anomalies (rd) ==! (optional part)
IF
(
PRESENT
(
prd
)
)
THEN
!== horizontal derivative of density anomalies (rd) ==! (optional part)
pgru
(:,:)
=
0._wp
pgru
(:,:)
=
0._wp
...
@@ -343,7 +343,7 @@ CONTAINS
...
@@ -343,7 +343,7 @@ CONTAINS
END_2D
END_2D
END
DO
END
DO
!
!
IF
(
nn_hls
==
1
)
CALL
lbc_lnk
(
'zpshde'
,
pgtu
(:,:,:)
,
'U'
,
-1.0_wp
,
pgtv
(:,:,:)
,
'V'
,
-1.0_wp
)
! Lateral boundary cond.
IF
(
nn_hls
==
1
)
CALL
lbc_lnk
(
'zpshde'
,
pgtu
,
'U'
,
-1.0_wp
,
pgtv
,
'V'
,
-1.0_wp
)
! Lateral boundary cond.
! horizontal derivative of density anomalies (rd)
! horizontal derivative of density anomalies (rd)
IF
(
PRESENT
(
prd
)
)
THEN
! depth of the partial step level
IF
(
PRESENT
(
prd
)
)
THEN
! depth of the partial step level
...
@@ -436,7 +436,7 @@ CONTAINS
...
@@ -436,7 +436,7 @@ CONTAINS
END_2D
END_2D
!
!
END
DO
END
DO
IF
(
nn_hls
==
1
)
CALL
lbc_lnk
(
'zpshde'
,
pgtui
(:,:,:)
,
'U'
,
-1.0_wp
,
pgtvi
(:,:,:)
,
'V'
,
-1.0_wp
)
! Lateral boundary cond.
IF
(
nn_hls
==
1
)
CALL
lbc_lnk
(
'zpshde'
,
pgtui
,
'U'
,
-1.0_wp
,
pgtvi
,
'V'
,
-1.0_wp
)
! Lateral boundary cond.
IF
(
PRESENT
(
prd
)
)
THEN
!== horizontal derivative of density anomalies (rd) ==! (optional part)
IF
(
PRESENT
(
prd
)
)
THEN
!== horizontal derivative of density anomalies (rd) ==! (optional part)
!
!
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment