Changeset 201 for LMDZ.3.3/branches/rel-LF/libf/phylmd
- Timestamp:
- Apr 6, 2001, 10:28:03 AM (24 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ.3.3/branches/rel-LF/libf/phylmd/interface_surf.F90
r182 r201 195 195 real, DIMENSION(klon):: zfra 196 196 logical :: cumul = .false. 197 logical :: scatter = .false. 197 198 198 199 if (check) write(*,*) 'Entree ', modname … … 342 343 ! appel a sechiba 343 344 ! 344 call interfsol(itime, klon, dtime, nisurf, knon, & 345 scatter= .true. 346 if (.not. scatter) then 347 call interfsol(itime, klon, dtime, nisurf, knon, & 345 348 & knindex, rlon, rlat, cufi, cvfi, iim, jjm, pctsrf, & 346 349 & debut, lafin, ok_veget, & … … 351 354 & evap, fluxsens, fluxlat, & 352 355 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s) 356 else 357 call interfsol_scat(itime, klon, dtime, nisurf, knon, & 358 & knindex, rlon, rlat, cufi, cvfi, iim, jjm, pctsrf, & 359 & debut, lafin, ok_veget, & 360 & zlev, u1_lay, v1_lay, temp_air, spechum, epot_air, ccanopy, & 361 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 362 & precip_rain, precip_snow, sollwdown, swnet, swdown, & 363 & tsurf, p1lay/100., ps, radsol, & 364 & evap, fluxsens, fluxlat, & 365 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s) 366 endif 353 367 endif 354 368 ! … … 801 815 endif 802 816 if ((.not. allocated(lon_scat))) then 803 allocate(lon_scat(iim,jjm ), stat = error)817 allocate(lon_scat(iim,jjm+1), stat = error) 804 818 if (error /= 0) then 805 819 abort_message='Pb allocation lon_scat' … … 808 822 endif 809 823 if ((.not. allocated(lat_scat))) then 810 allocate(lat_scat(iim,jjm ), stat = error)824 allocate(lat_scat(iim,jjm+1), stat = error) 811 825 if (error /= 0) then 812 826 abort_message='Pb allocation lat_scat' … … 839 853 lon_scat(:,1) = lon_scat(:,2) 840 854 lat_scat(:,1) = rlat(1) 855 lon_scat(:,jjm+1) = lon_scat(:,2) 856 lat_scat(:,jjm+1) = rlat(klon) 841 857 842 858 ! … … 916 932 peqB_orc = peqAcoef 917 933 918 call intersurf_main (itime, iim, jjm, knon, knindex, dtime, & 934 ! 935 ! Init Orchidee 936 ! 937 if (debut) then 938 call intersurf_main (itime-1, iim, jjm+1, knon, knindex, dtime, & 919 939 & lrestart_read, lrestart_write, lalo, & 920 940 & contfrac, neighbours, resolution, date0, & … … 925 945 & tsol_rad, tsurf_new, qsurf, albedo_out, emis_new, z0_new, & 926 946 & lon_scat, lat_scat) 947 endif 948 949 call intersurf_main (itime, iim, jjm+1, knon, knindex, dtime, & 950 & lrestart_read, lrestart_write, lalo, & 951 & contfrac, neighbours, resolution, date0, & 952 & zlev, u1_lay, v1_lay, spechum, temp_air, epot_air, ccanopy, & 953 & tq_cdrag, petA_orc, peqA_orc, petB_orc, peqB_orc, & 954 & precip_rain, precip_snow, lwdown, swnet, swdown, p1lay, & 955 & evap, fluxsens, fluxlat, coastalflow, riverflow, & 956 & tsol_rad, tsurf_new, qsurf, albedo_out, emis_new, z0_new, & 957 & lon_scat, lat_scat) 927 958 928 959 alb_new(:) = albedo_out(:,1) 929 960 930 961 END SUBROUTINE interfsol 962 ! 963 !######################################################################### 964 ! 965 SUBROUTINE interfsol_scat(itime, klon, dtime, nisurf, knon, & 966 & knindex, rlon, rlat, cufi, cvfi, iim, jjm, pctsrf, & 967 & debut, lafin, ok_veget, & 968 & zlev, u1_lay, v1_lay, temp_air, spechum, epot_air, ccanopy, & 969 & tq_cdrag, petAcoef, peqAcoef, petBcoef, peqBcoef, & 970 & precip_rain, precip_snow, lwdown, swnet, swdown, & 971 & tsurf, p1lay, ps, radsol, & 972 & evap, fluxsens, fluxlat, & 973 & tsol_rad, tsurf_new, alb_new, emis_new, z0_new, dflux_l, dflux_s) 974 975 USE intersurf 976 977 ! Cette routine sert d'interface entre le modele atmospherique et le 978 ! modele de sol continental. Appel a sechiba 979 ! 980 ! L. Fairhead 02/2000 981 ! 982 ! input: 983 ! itime numero du pas de temps 984 ! klon nombre total de points de grille 985 ! dtime pas de temps de la physique (en s) 986 ! nisurf index de la surface a traiter (1 = sol continental) 987 ! knon nombre de points de la surface a traiter 988 ! knindex index des points de la surface a traiter 989 ! rlon longitudes de la grille entiere 990 ! rlat latitudes de la grille entiere 991 ! pctsrf tableau des fractions de surface de chaque maille 992 ! debut logical: 1er appel a la physique (lire les restart) 993 ! lafin logical: dernier appel a la physique (ecrire les restart) 994 ! ok_veget logical: appel ou non au schema de surface continental 995 ! (si false calcul simplifie des fluxs sur les continents) 996 ! zlev hauteur de la premiere couche 997 ! u1_lay vitesse u 1ere couche 998 ! v1_lay vitesse v 1ere couche 999 ! temp_air temperature de l'air 1ere couche 1000 ! spechum humidite specifique 1ere couche 1001 ! epot_air temp pot de l'air 1002 ! ccanopy concentration CO2 canopee 1003 ! tq_cdrag cdrag 1004 ! petAcoef coeff. A de la resolution de la CL pour t 1005 ! peqAcoef coeff. A de la resolution de la CL pour q 1006 ! petBcoef coeff. B de la resolution de la CL pour t 1007 ! peqBcoef coeff. B de la resolution de la CL pour q 1008 ! precip_rain precipitation liquide 1009 ! precip_snow precipitation solide 1010 ! lwdown flux IR descendant a la surface 1011 ! swnet flux solaire net 1012 ! swdown flux solaire entrant a la surface 1013 ! tsurf temperature de surface 1014 ! p1lay pression 1er niveau (milieu de couche) 1015 ! ps pression au sol 1016 ! radsol rayonnement net aus sol (LW + SW) 1017 ! 1018 ! 1019 ! input/output 1020 ! run_off ruissellement total 1021 ! 1022 ! output: 1023 ! evap evaporation totale 1024 ! fluxsens flux de chaleur sensible 1025 ! fluxlat flux de chaleur latente 1026 ! tsol_rad 1027 ! tsurf_new temperature au sol 1028 ! alb_new albedo 1029 ! emis_new emissivite 1030 ! z0_new surface roughness 1031 1032 1033 ! Parametres d'entree 1034 integer, intent(IN) :: itime 1035 integer, intent(IN) :: klon 1036 real, intent(IN) :: dtime 1037 integer, intent(IN) :: nisurf 1038 integer, intent(IN) :: knon 1039 integer, intent(IN) :: iim, jjm 1040 integer, dimension(klon), intent(IN) :: knindex 1041 logical, intent(IN) :: debut, lafin, ok_veget 1042 real, dimension(klon,nbsrf), intent(IN) :: pctsrf 1043 real, dimension(klon), intent(IN) :: rlon, rlat 1044 real, dimension(klon), intent(IN) :: cufi, cvfi 1045 real, dimension(klon), intent(IN) :: zlev 1046 real, dimension(klon), intent(IN) :: u1_lay, v1_lay 1047 real, dimension(klon), intent(IN) :: temp_air, spechum 1048 real, dimension(klon), intent(IN) :: epot_air, ccanopy 1049 real, dimension(klon), intent(INOUT) :: tq_cdrag 1050 real, dimension(klon), intent(IN) :: petAcoef, peqAcoef 1051 real, dimension(klon), intent(IN) :: petBcoef, peqBcoef 1052 real, dimension(klon), intent(IN) :: precip_rain, precip_snow 1053 real, dimension(klon), intent(IN) :: lwdown, swnet, swdown, ps 1054 real, dimension(klon), intent(IN) :: tsurf, p1lay 1055 real, dimension(klon), intent(IN) :: radsol 1056 ! Parametres de sortie 1057 real, dimension(klon), intent(OUT):: evap, fluxsens, fluxlat 1058 real, dimension(klon), intent(OUT):: tsol_rad, tsurf_new, alb_new 1059 real, dimension(klon), intent(OUT):: emis_new, z0_new 1060 real, dimension(klon), intent(OUT):: dflux_s, dflux_l 1061 1062 ! Local 1063 ! 1064 integer :: ii, ij, jj, igrid, ireal, i, index 1065 integer :: error 1066 character (len = 20) :: modname = 'interfsol_scat' 1067 character (len = 80) :: abort_message 1068 logical,save :: check = .TRUE. 1069 real, dimension(klon) :: cal, beta, dif_grnd, capsol 1070 ! type de couplage dans sechiba 1071 ! character (len=10) :: coupling = 'implicit' 1072 ! drapeaux controlant les appels dans SECHIBA 1073 ! type(control_type), save :: control_in 1074 ! coordonnees geographiques 1075 real, allocatable, dimension(:,:), save :: lalo 1076 ! pts voisins 1077 integer,allocatable, dimension(:,:), save :: neighbours 1078 ! fractions continents 1079 real,allocatable, dimension(:), save :: contfrac 1080 ! resolution de la grille 1081 real, allocatable, dimension (:,:), save :: resolution 1082 ! correspondance point n -> indices (i,j) 1083 integer, allocatable, dimension(:,:), save :: correspond 1084 ! offset pour calculer les point voisins 1085 integer, dimension(8,3), save :: off_ini 1086 integer, dimension(8), save :: offset 1087 ! Identifieurs des fichiers restart et histoire 1088 integer, save :: rest_id, hist_id 1089 integer, save :: rest_id_stom, hist_id_stom 1090 ! 1091 real, allocatable, dimension (:,:), save :: lon_scat, lat_scat 1092 1093 logical, save :: lrestart_read = .true. , lrestart_write = .false. 1094 1095 real, dimension(klon):: qsurf 1096 real, dimension(klon):: snow, qsol 1097 real, save :: date0 = 0. 1098 real, dimension(knon,2) :: albedo_out 1099 ! Pb de nomenclature 1100 real, dimension(klon) :: petA_orc, petB_orc, peqA_orc, peqB_orc 1101 ! champs a passer a ORCHIDEE 1102 real, dimension(:,:), allocatable, save :: lon_sc, lat_sc, contfrac_sc 1103 real, dimension(iim,jjm+1) :: zlev_sc 1104 real, dimension(iim,jjm+1) :: u1_lay_sc, v1_lay_sc, spechum_sc, temp_air_sc 1105 real, dimension(iim,jjm+1) :: epot_air_sc, ccanopy_sc, tq_cdrag_sc 1106 real, dimension(iim,jjm+1) :: petA_or_sc, peqA_or_sc, petB_or_sc, peqB_or_sc 1107 real, dimension(iim,jjm+1) :: precip_rain_sc, precip_snow_sc, lwdown_sc 1108 real, dimension(iim,jjm+1) :: swnet_sc, swdown_sc, p1lay_sc, evap_sc 1109 real, dimension(iim,jjm+1) :: fluxsens_sc, fluxlat_sc, coastalflow_sc 1110 real, dimension(iim,jjm+1) :: riverflow_sc, tsol_rad_sc, tsurf_new_sc 1111 real, dimension(iim,jjm+1) :: qsurf_sc, emis_new_sc, z0_new_sc 1112 real, dimension(iim,jjm+1,2) :: albedo_out_sc 1113 1114 if (check) write(*,*)'Entree ', modname 1115 if (check) write(*,*)'ok_veget = ',ok_veget 1116 1117 ! initialisation 1118 if (debut) then 1119 if ((.not. allocated(lon_sc))) then 1120 allocate(lon_sc(iim,jjm+1), stat = error) 1121 if (error /= 0) then 1122 abort_message='Pb allocation lon_sc' 1123 call abort_gcm(modname,abort_message,1) 1124 endif 1125 endif 1126 if ((.not. allocated(lat_sc))) then 1127 allocate(lat_sc(iim,jjm+1), stat = error) 1128 if (error /= 0) then 1129 abort_message='Pb allocation lat_sc' 1130 call abort_gcm(modname,abort_message,1) 1131 endif 1132 endif 1133 index = 1 1134 do jj = 2, jjm 1135 do ij = 1, iim 1136 index = index + 1 1137 lon_sc(ij,jj) = rlon(index) 1138 lat_sc(ij,jj) = rlat(index) 1139 enddo 1140 enddo 1141 lon_sc(:,1) = lon_sc(:,2) 1142 lat_sc(:,1) = rlat(1) 1143 lon_sc(:,jjm+1) = lon_sc(:,jjm) 1144 lat_sc(:,jjm+1) = rlat(klon) 1145 if (( .not. allocated(contfrac_sc))) then 1146 allocate(contfrac_sc(iim, jjm+1), stat = error) 1147 if (error /= 0) then 1148 abort_message='Pb allocation contfrac' 1149 call abort_gcm(modname,abort_message,1) 1150 endif 1151 endif 1152 contfrac_sc = 0. 1153 call gath2cpl(pctsrf(:,is_ter), contfrac_sc, klon, knon,iim,jjm, knindex) 1154 endif ! (fin debut) 1155 1156 ! 1157 ! Appel a la routine sols continentaux 1158 ! 1159 ! petit pb de nomenclature 1160 ! 1161 if (lafin) lrestart_write = .true. 1162 if (check) write(*,*)'lafin ',lafin,lrestart_write 1163 1164 petA_orc = petBcoef * dtime 1165 petB_orc = petAcoef 1166 peqA_orc = peqBcoef * dtime 1167 peqB_orc = peqAcoef 1168 1169 ! 1170 ! Passage sur la grille 2D avant envoi a ORCHIDEE 1171 ! 1172 call gath2cpl(zlev, zlev_sc, klon, knon,iim,jjm, knindex) 1173 call gath2cpl(u1_lay, u1_lay_sc, klon, knon,iim,jjm, knindex) 1174 call gath2cpl(v1_lay, v1_lay_sc, klon, knon,iim,jjm, knindex) 1175 call gath2cpl(spechum, spechum_sc, klon, knon,iim,jjm, knindex) 1176 call gath2cpl(temp_air, temp_air_sc, klon, knon,iim,jjm, knindex) 1177 call gath2cpl(epot_air, epot_air_sc, klon, knon,iim,jjm, knindex) 1178 call gath2cpl(ccanopy, ccanopy_sc, klon, knon,iim,jjm, knindex) 1179 call gath2cpl(tq_cdrag, tq_cdrag_sc, klon, knon,iim,jjm, knindex) 1180 call gath2cpl(petA_orc, petA_or_sc, klon, knon,iim,jjm, knindex) 1181 call gath2cpl(peqA_orc, peqA_or_sc, klon, knon,iim,jjm, knindex) 1182 call gath2cpl(petB_orc, petB_or_sc, klon, knon,iim,jjm, knindex) 1183 call gath2cpl(peqB_orc, peqB_or_sc, klon, knon,iim,jjm, knindex) 1184 call gath2cpl(precip_rain, precip_rain_sc, klon, knon,iim,jjm, knindex) 1185 call gath2cpl(precip_snow, precip_snow_sc, klon, knon,iim,jjm, knindex) 1186 call gath2cpl(lwdown, lwdown_sc, klon, knon,iim,jjm, knindex) 1187 call gath2cpl(swnet, swnet_sc, klon, knon,iim,jjm, knindex) 1188 call gath2cpl(swdown, swdown_sc, klon, knon,iim,jjm, knindex) 1189 call gath2cpl(p1lay, p1lay_sc, klon, knon,iim,jjm, knindex) 1190 ! 1191 ! Init Orchidee 1192 ! 1193 if (debut) then 1194 call intersurf_main (itime-1, iim, jjm+1 , knon, knindex, dtime, & 1195 & lrestart_read, lrestart_write, lon_sc, lat_sc, & 1196 & contfrac_sc, date0, zlev_sc, u1_lay_sc, v1_lay_sc, & 1197 & spechum_sc, temp_air_sc, epot_air_sc, ccanopy_sc, & 1198 & tq_cdrag_sc, petA_or_sc, peqA_or_sc, petB_or_sc, peqB_or_sc, & 1199 & precip_rain_sc, precip_snow_sc, lwdown_sc, swnet_sc, & 1200 & swdown_sc, p1lay_sc, & 1201 & evap_sc, fluxsens_sc, fluxlat_sc, & 1202 & coastalflow_sc, riverflow_sc, tsol_rad_sc, tsurf_new_sc, & 1203 & qsurf_sc, albedo_out_sc, emis_new_sc, z0_new_sc) 1204 endif 1205 1206 call intersurf_main (itime, iim, jjm+1 , knon, knindex, dtime, & 1207 & lrestart_read, lrestart_write, lon_sc, lat_sc, & 1208 & contfrac_sc, date0, zlev_sc, u1_lay_sc, v1_lay_sc, & 1209 & spechum_sc, temp_air_sc, epot_air_sc, ccanopy_sc, & 1210 & tq_cdrag_sc, petA_or_sc, peqA_or_sc, petB_or_sc, peqB_or_sc, & 1211 & precip_rain_sc, precip_snow_sc, lwdown_sc, swnet_sc, & 1212 & swdown_sc, p1lay_sc, & 1213 & evap_sc, fluxsens_sc, fluxlat_sc, & 1214 & coastalflow_sc, riverflow_sc, tsol_rad_sc, tsurf_new_sc, & 1215 & qsurf_sc, albedo_out_sc, emis_new_sc, z0_new_sc) 1216 ! 1217 ! sorties mises sur la grille physique 1218 ! 1219 1220 call cpl2gath(evap_sc, evap, klon, knon,iim,jjm, knindex) 1221 call cpl2gath(fluxsens_sc, fluxsens, klon, knon,iim,jjm, knindex) 1222 call cpl2gath(fluxlat_sc, fluxlat, klon, knon,iim,jjm, knindex) 1223 call cpl2gath(coastalflow_sc, coastalflow, klon, knon,iim,jjm, knindex) 1224 call cpl2gath(riverflow_sc, riverflow, klon, knon,iim,jjm, knindex) 1225 call cpl2gath(tsol_rad_sc, tsol_rad, klon, knon,iim,jjm, knindex) 1226 call cpl2gath(tsurf_new_sc, tsurf_new, klon, knon,iim,jjm, knindex) 1227 call cpl2gath(qsurf_sc, qsurf, klon, knon,iim,jjm, knindex) 1228 call cpl2gath(albedo_out_sc(:,:,1), alb_new, klon, knon,iim,jjm, knindex) 1229 call cpl2gath(emis_new_sc, emis_new, klon, knon,iim,jjm, knindex) 1230 call cpl2gath(z0_new_sc, z0_new, klon, knon,iim,jjm, knindex) 1231 1232 ! LF essai sensible 1233 fluxsens = -1. * fluxsens 1234 fluxlat = -1. * fluxlat 1235 1236 if (debut) lrestart_read = .false. 1237 1238 END SUBROUTINE interfsol_scat 931 1239 ! 932 1240 !#########################################################################
Note: See TracChangeset
for help on using the changeset viewer.