Ignore:
Timestamp:
May 18, 2015, 5:25:29 PM (10 years ago)
Author:
Laurent Fairhead
Message:

Backport of trunk revisions 2271, 2279, 2280, 2282 into LMDZ6_rc0 branch:

  • modifications for NMC/XIOS
Location:
LMDZ5/branches/LMDZ6_rc0/libf
Files:
11 edited

Legend:

Unmodified
Added
Removed
  • LMDZ5/branches/LMDZ6_rc0/libf/bibio/wxios.F90

    r2160 r2283  
    2121    CHARACTER(len=100) :: g_field_name = "nofield"
    2222!$OMP THREADPRIVATE(g_flag_xml,g_field_name)
    23 
     23    REAL :: missing_val_omp
     24    REAL :: missing_val
     25!$OMP THREADPRIVATE(missing_val)
    2426
    2527    CONTAINS
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/calcul_STDlev.h

    r1921 r2283  
    44!IM on initialise les variables
    55!
    6         missing_val=nf90_fill_real
     6!       missing_val=nf90_fill_real
    77!
    88        CALL ini_undefSTD(itap,itapm1)
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/declare_STDlev.h

    r1910 r2283  
    5757      REAL zx_tmp_fiNC(klon,nlevSTD)
    5858
    59       REAL missing_val
     59!     REAL missing_val
    6060      REAL, SAVE :: freq_moyNMC(nout)
    6161!$OMP THREADPRIVATE(freq_moyNMC)
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/moy_undefSTD.F90

    r1999 r2283  
    55  USE netcdf
    66  USE dimphy
     7#ifdef CPP_IOIPSL
    78  USE phys_state_var_mod
     9#endif
     10
    811  USE phys_cal_mod, ONLY: mth_len
    912  IMPLICIT NONE
    1013  include "clesphys.h"
     14#ifdef CPP_IOIPSL
     15  REAL :: missing_val
     16#endif
    1117
    1218  ! ====================================================================
     
    5157  REAL un_jour
    5258  PARAMETER (un_jour=86400.)
    53   REAL missing_val
     59! REAL missing_val
    5460
    55   missing_val = nf90_fill_real
     61! missing_val = nf90_fill_real
     62#ifndef CPP_XIOS
     63      missing_val=missing_val_nf90
     64#endif
    5665
    5766  DO n = 1, nout
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/phys_output_ctrlout_mod.F90

    r2160 r2283  
    557557
    558558  TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_wSTDlevs     = (/                    &
    559       ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'w850', "Vertical wind 1hPa", "Pa/s", &
     559      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'w850', "Vertical wind 850hPa", "Pa/s", &
    560560      (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), &
    561561      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'w700', "Vertical wind 700hPa", "Pa/s", &
     
    573573
    574574  TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_tSTDlevs     = (/                    &
    575       ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'t850', "Temperature 1hPa", "K",      &
     575      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'t850', "Temperature 850hPa", "K",      &
    576576      (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), &
    577577      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'t700', "Temperature 700hPa", "K",      &
     
    589589
    590590  TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_qSTDlevs     = (/                             &
    591       ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'q850', "Specific humidity 1hPa", &
     591      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'q850', "Specific humidity 850hPa", &
    592592      "kg/kg", (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), &
    593593      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'q700', "Specific humidity 700hPa", &
     
    605605
    606606  TYPE(ctrl_out), SAVE, DIMENSION(7) :: o_zSTDlevs   = (/                           &
    607       ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'z850', "Geopotential height 1hPa",        &
     607      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'z850', "Geopotential height 850hPa",        &
    608608      "m", (/ 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)', 'inst(X)' /)), &
    609609      ctrl_out((/ 1, 7, 7, 10, 10, 10, 11, 11, 11 /),'z700', "Geopotential height 700hPa",        &
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/phys_output_write_mod.F90

    r2160 r2283  
    171171         vqsumSTD, vTsumSTD, O3daysumSTD, wqsumSTD, &
    172172         vphisumSTD, wTsumSTD, u2sumSTD, v2sumSTD, &
    173          T2sumSTD, nlevSTD, du_gwd_rando, dv_gwd_rando
     173         T2sumSTD, nlevSTD, du_gwd_rando, dv_gwd_rando, &
     174         ulevSTD, vlevSTD, wlevSTD, philevSTD, qlevSTD, tlevSTD, &
     175         rhlevSTD, O3STD, O3daySTD, uvSTD, vqSTD, vTSTD, wqSTD, &
     176         vphiSTD, wTSTD, u2STD, v2STD, T2STD, missing_val_nf90
    174177
    175178    USE phys_local_var_mod, only: zxfluxlat, slp, zxtsol, zt2m, &
     
    239242    ! ug Pour les sorties XIOS
    240243    USE xios, ONLY: xios_update_calendar
    241     USE wxios, only: wxios_closedef
     244    USE wxios, only: wxios_closedef, missing_val
    242245#endif
    243246    USE phys_cal_mod, only : mth_len
     
    285288    INTEGER, DIMENSION(iim*jjmp1*klev) :: ndex3d
    286289    REAL, PARAMETER :: dobson_u = 2.1415e-05 ! Dobson unit, in kg m-2
    287     REAL, PARAMETER :: missing_val=nf90_fill_real
     290!   REAL, PARAMETER :: missing_val=nf90_fill_real
     291#ifndef CPP_XIOS
     292    REAL :: missing_val
     293#endif
    288294    REAL, PARAMETER :: un_jour=86400.
    289295
     
    646652       !       ENDIF
    647653
     654#ifdef CPP_IOIPSL
     655#ifndef CPP_XIOS
     656  IF (.NOT.ok_all_xml) THEN
    648657       ! ATTENTION, LES ANCIENS HISTWRITE ONT ETES CONSERVES EN ATTENDANT MIEUX:
    649658       ! Champs interpolles sur des niveaux de pression
     659       missing_val=missing_val_nf90
    650660       DO iff=1, nfiles
    651661          ll=0
     
    669679          ENDDO
    670680       ENDDO
    671 
     681  ENDIF
     682#endif
     683#endif
     684#ifdef CPP_XIOS
     685  IF(ok_all_xml) THEN
     686!XIOS  CALL xios_get_field_attr("u850",default_value=missing_val)
     687!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
     688          ll=0
     689          DO k=1, nlevSTD
     690             bb2=clevSTD(k)
     691             IF(bb2.EQ."850".OR.bb2.EQ."700".OR. &
     692                bb2.EQ."500".OR.bb2.EQ."200".OR. &
     693                bb2.EQ."100".OR. &
     694                bb2.EQ."50".OR.bb2.EQ."10") THEN
     695                ll=ll+1
     696                CALL histwrite_phy(o_uSTDlevs(ll),ulevSTD(:,k))
     697                CALL histwrite_phy(o_vSTDlevs(ll),vlevSTD(:,k))
     698                CALL histwrite_phy(o_wSTDlevs(ll),wlevSTD(:,k))
     699                CALL histwrite_phy(o_zSTDlevs(ll),philevSTD(:,k))
     700                CALL histwrite_phy(o_qSTDlevs(ll),qlevSTD(:,k))
     701                CALL histwrite_phy(o_tSTDlevs(ll),tlevSTD(:,k))
     702             ENDIF !(bb2.EQ."850".OR.bb2.EQ."700".OR.
     703          ENDDO
     704  ENDIF
     705#endif
    672706       IF (vars_defined) THEN
    673707          DO i=1, klon
     
    12511285       ENDIF
    12521286!!!!!!!!!!!! Sorties niveaux de pression NMC !!!!!!!!!!!!!!!!!!!!
     1287#ifdef CPP_IOIPSL
     1288#ifndef CPP_XIOS
     1289  IF (.NOT.ok_all_xml) THEN
     1290       ! ATTENTION, LES ANCIENS HISTWRITE ONT ETES CONSERVES EN ATTENDANT MIEUX:
     1291       ! Champs interpolles sur des niveaux de pression
     1292       missing_val=missing_val_nf90
    12531293       DO iff=7, nfiles
    12541294
     
    13141354          CALL histwrite_phy(o_TxT,T2sumSTD(:,:,iff-6),iff)
    13151355       ENDDO !nfiles
     1356  ENDIF
     1357#endif
     1358#endif
     1359#ifdef CPP_XIOS
     1360  IF(ok_all_xml) THEN
     1361!      DO iff=7, nfiles
     1362
     1363!         CALL histwrite_phy(o_tnondef,tnondef(:,:,3))
     1364          CALL histwrite_phy(o_ta,tlevSTD(:,:))
     1365          CALL histwrite_phy(o_zg,philevSTD(:,:))
     1366          CALL histwrite_phy(o_hus,qlevSTD(:,:))
     1367          CALL histwrite_phy(o_hur,rhlevSTD(:,:))
     1368          CALL histwrite_phy(o_ua,ulevSTD(:,:))
     1369          CALL histwrite_phy(o_va,vlevSTD(:,:))
     1370          CALL histwrite_phy(o_wap,wlevSTD(:,:))
     1371!         IF(vars_defined) THEN
     1372!            DO k=1, nlevSTD
     1373!               DO i=1, klon
     1374!                  IF(tnondef(i,k,3).NE.missing_val) THEN
     1375!                     IF(freq_outNMC(iff-6).LT.0) THEN
     1376!                        freq_moyNMC(iff-6)=(mth_len*un_jour)/freq_calNMC(iff-6)
     1377!                     ELSE
     1378!                        freq_moyNMC(iff-6)=freq_outNMC(iff-6)/freq_calNMC(iff-6)
     1379!                     ENDIF
     1380!                     zx_tmp_fi3d_STD(i,k) = (100.*tnondef(i,k,3))/freq_moyNMC(iff-6)
     1381!                  ELSE
     1382!                     zx_tmp_fi3d_STD(i,k) = missing_val
     1383!                  ENDIF
     1384!               ENDDO
     1385!            ENDDO
     1386!         ENDIF
     1387!         CALL histwrite_phy(o_psbg,zx_tmp_fi3d_STD)
     1388          IF(vars_defined) THEN
     1389             DO k=1, nlevSTD
     1390                DO i=1, klon
     1391                   IF(O3STD(i,k).NE.missing_val) THEN
     1392                      zx_tmp_fi3d_STD(i,k) = O3STD(i,k) * 1.e+9
     1393                   ELSE
     1394                      zx_tmp_fi3d_STD(i,k) = missing_val
     1395                   ENDIF
     1396                ENDDO
     1397             ENDDO !k=1, nlevSTD
     1398          ENDIF
     1399          CALL histwrite_phy(o_tro3,zx_tmp_fi3d_STD)
     1400          if (read_climoz == 2) THEN
     1401             IF(vars_defined) THEN
     1402                DO k=1, nlevSTD
     1403                   DO i=1, klon
     1404                      IF(O3daySTD(i,k).NE.missing_val) THEN
     1405                         zx_tmp_fi3d_STD(i,k) = O3daySTD(i,k) * 1.e+9
     1406                      ELSE
     1407                         zx_tmp_fi3d_STD(i,k) = missing_val
     1408                      ENDIF
     1409                   ENDDO
     1410                ENDDO !k=1, nlevSTD
     1411             ENDIF
     1412             CALL histwrite_phy(o_tro3_daylight,zx_tmp_fi3d_STD)
     1413          endif
     1414          CALL histwrite_phy(o_uxv,uvSTD(:,:))
     1415          CALL histwrite_phy(o_vxq,vqSTD(:,:))
     1416          CALL histwrite_phy(o_vxT,vTSTD(:,:))
     1417          CALL histwrite_phy(o_wxq,wqSTD(:,:))
     1418          CALL histwrite_phy(o_vxphi,vphiSTD(:,:))
     1419          CALL histwrite_phy(o_wxT,wTSTD(:,:))
     1420          CALL histwrite_phy(o_uxu,u2STD(:,:))
     1421          CALL histwrite_phy(o_vxv,v2STD(:,:))
     1422          CALL histwrite_phy(o_TxT,T2STD(:,:))
     1423!      ENDDO !nfiles
     1424  ENDIF
     1425#endif
    13161426!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
    13171427        IF (nqtot.GE.nqo+1) THEN
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/phys_state_var_mod.F90

    r2160 r2283  
    1010! Declaration des variables
    1111      USE dimphy
     12      USE netcdf, only: nf90_fill_real
    1213      INTEGER, PARAMETER :: nlevSTD=17
    1314      INTEGER, PARAMETER :: nlevSTD8=8
     
    1617      INTEGER, PARAMETER :: napisccp=1
    1718      INTEGER, SAVE :: radpas
     19      REAL, PARAMETER :: missing_val_nf90=nf90_fill_real
    1820!$OMP THREADPRIVATE(radpas)
    1921      REAL, SAVE :: dtime, solaire_etat0
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/physiq.F90

    r2160 r2283  
    4747  use phyaqua_mod, only: zenang_an
    4848  USE control_mod
     49#ifdef CPP_XIOS
     50  USE wxios, ONLY: missing_val, missing_val_omp
     51  USE xios, ONLY: xios_get_field_attr
     52#endif
    4953#ifdef REPROBUS
    5054  USE CHEM_REP, ONLY : Init_chem_rep_xjour
     
    240244  real da(klon,klev),phi(klon,klev,klev),mp(klon,klev)
    241245  real wght_cvfd(klon,klev)
     246#ifndef CPP_XIOS
     247  REAL, SAVE :: missing_val
     248#endif
    242249  ! Variables pour le lessivage convectif
    243250  ! RomP >>>
     
    36743681  !IM Interpolation sur les niveaux de pression du NMC
    36753682  !   -------------------------------------------------
     3683#ifdef CPP_XIOS
     3684          !$OMP MASTER
     3685          !On recupere la valeur de la missing value donnee dans le xml
     3686          CALL xios_get_field_attr("t850",default_value=missing_val_omp)
     3687!         PRINT *,"ARNAUD value missing ",missing_val_omp
     3688          !$OMP END MASTER
     3689          !$OMP BARRIER
     3690          missing_val=missing_val_omp
     3691#endif
     3692#ifndef CPP_XIOS
     3693          missing_val=missing_val_nf90
     3694#endif
    36763695  !
    36773696  include "calcul_STDlev.h"
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/plevel.F90

    r1999 r2283  
    99  USE netcdf
    1010  USE dimphy
     11#ifdef CPP_IOIPSL
     12  USE phys_state_var_mod, ONLY: missing_val_nf90
     13#endif
     14#ifdef CPP_XIOS
     15  USE wxios, ONLY: missing_val
     16#endif
    1117  IMPLICIT NONE
    1218
     
    5662  INTEGER i, k
    5763
    58   REAL missing_val
     64! REAL missing_val
     65#ifndef CPP_XIOS
     66  REAL :: missing_val
     67#endif
    5968
    60   missing_val = nf90_fill_real
     69! missing_val = nf90_fill_real
     70
     71#ifndef CPP_XIOS
     72      missing_val=missing_val_nf90
     73#endif
    6174
    6275  IF (first) THEN
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/plevel_new.F90

    r1999 r2283  
    1010  USE netcdf
    1111  USE dimphy
     12#ifdef CPP_IOIPSL
     13  USE phys_state_var_mod, ONLY: missing_val_nf90
     14#endif
     15#ifdef CPP_XIOS
     16  USE wxios, ONLY: missing_val
     17#endif
     18
    1219  IMPLICIT NONE
    1320
     
    5865  INTEGER i, k
    5966
    60   REAL missing_val
     67! REAL missing_val
     68#ifndef CPP_XIOS
     69  REAL :: missing_val
     70#endif
    6171
    62   missing_val = nf90_fill_real
     72! missing_val = nf90_fill_real
     73
     74#ifndef CPP_XIOS
     75      missing_val=missing_val_nf90
     76#endif
    6377
    6478  IF (first) THEN
  • LMDZ5/branches/LMDZ6_rc0/libf/phylmd/undefSTD.F90

    r1999 r2283  
    55  USE netcdf
    66  USE dimphy
    7   USE phys_state_var_mod ! Variables sauvegardees de la physique
     7#ifdef CPP_IOIPSL
     8  USE phys_state_var_mod
     9#endif
     10
    811  IMPLICIT NONE
    912  include "clesphys.h"
     13#ifdef CPP_IOIPSL
     14  REAL :: missing_val
     15#endif
    1016
    1117  ! ====================================================================
     
    5157  ! REAL tnondef(klon,klevSTD,nout)
    5258
    53   REAL missing_val
     59! REAL missing_val
    5460
    55   missing_val = nf90_fill_real
     61! missing_val = nf90_fill_real
     62#ifndef CPP_XIOS
     63      missing_val=missing_val_nf90
     64#endif
    5665
    5766  DO n = 1, nout
Note: See TracChangeset for help on using the changeset viewer.