Changeset 1927


Ignore:
Timestamp:
11/22/12 14:54:21 (9 years ago)
Author:
dsolyga
Message:

Introduced the new subroutine moycum_index. Works the same way as moycum but make computations only on index points. Used only when scatter operation is performed. Help to reduce the computational time of ORCHIDEE. For the other models, should not change the results.

Location:
IOIPSL/trunk/src
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • IOIPSL/trunk/src/histcom.f90

    r1525 r1927  
    99!- 
    1010  USE stringop, ONLY : nocomma,cmpblank,findpos,find_str,strlowercase 
    11   USE mathelp,  ONLY : mathop,moycum,buildop 
     11  USE mathelp,  ONLY : mathop,moycum,moycum_index,buildop 
    1212  USE fliocom,  ONLY : flio_dom_file,flio_dom_att 
    1313  USE calendar 
     
    12061206 &    .AND.(TRIM(W_F(idf)%W_V(iv)%topp) /= "never") )THEN 
    12071207    ALLOCATE(W_F(idf)%W_V(iv)%t_bf(buff_sz)) 
    1208     W_F(idf)%W_V(iv)%t_bf(:) = 0. 
     1208    W_F(idf)%W_V(iv)%t_bf(:) = missing_val 
    12091209    IF (l_dbg) THEN 
    12101210      WRITE(ipslout,*) "histdef : 3.0 allocating time_buffer for", & 
     
    18921892  INTEGER,DIMENSION(4) :: corner,edges 
    18931893  INTEGER :: itime 
     1894  LOGICAL :: flag 
    18941895!- 
    18951896  REAL :: rtime 
     
    20522053    IF (     (TRIM(tmp_opp) /= "inst") & 
    20532054 &      .AND.(TRIM(tmp_opp) /= "once") ) THEN 
    2054       CALL moycum(tmp_opp,tsz,W_F(idf)%W_V(iv)%t_bf, & 
    2055  &           tbf_2,W_F(idf)%W_V(iv)%nb_opp) 
     2055 
     2056!- 
     2057!------ 5.1 Check if scatter operation is performed 
     2058!-       
     2059       flag = .FALSE.  
     2060       DO io = 1, nbopp_max 
     2061          IF ( INDEX(TRIM(W_F(idf)%W_V(iv)%sopp(io)),'scatter') > 0 ) THEN  
     2062             flag = .TRUE.  
     2063          END IF 
     2064       END DO 
     2065 
     2066       IF ( flag ) THEN 
     2067!- 
     2068!------ 5.2  Enter moycum_index only if a scatter operation is performed 
     2069!-          
     2070          IF (l_dbg) & 
     2071               & WRITE(ipslout,*) "histwrite: 5.2 moycum_index",nbindex,nx,ny,nz 
     2072          CALL moycum_index(tmp_opp, W_F(idf)%W_V(iv)%t_bf, & 
     2073 &             tbf_2, W_F(idf)%W_V(iv)%nb_opp, nbindex, nindex) 
     2074       ELSE 
     2075!- 
     2076!------ 5.3  Enter moycum otherwise 
     2077!- 
     2078          IF (l_dbg) & 
     2079               & WRITE(ipslout,*) "histwrite: 5.3 moycum",nbindex,nx,ny 
     2080          CALL moycum(tmp_opp,tsz,W_F(idf)%W_V(iv)%t_bf, & 
     2081               &           tbf_2,W_F(idf)%W_V(iv)%nb_opp) 
     2082       END IF 
     2083 
    20562084    ENDIF 
    20572085!- 
  • IOIPSL/trunk/src/mathelp.f90

    r845 r1927  
    1010!- 
    1111  PRIVATE 
    12   PUBLIC :: mathop,moycum,buildop 
     12  PUBLIC :: mathop,moycum,moycum_index,buildop 
    1313!- 
    1414  INTERFACE mathop 
     
    31193119END SUBROUTINE moycum 
    31203120!=== 
     3121SUBROUTINE moycum_index( opp, px, py, pwx, nbi, ind ) 
     3122!--------------------------------------------------------------------- 
     3123!- Does time operations on index points  
     3124!--------------------------------------------------------------------- 
     3125  IMPLICIT NONE 
     3126!- 
     3127 
     3128  !! 0. Parameters and variables declaration 
     3129 
     3130  !! 0.1 Input variables 
     3131 
     3132  CHARACTER(LEN=7), INTENT(in)        :: opp  !! Operation performed 
     3133  INTEGER, INTENT(in)                 :: nbi  !! Size of index vector 
     3134  INTEGER, DIMENSION(nbi), INTENT(in) :: ind  !! Index vector 
     3135  REAL, DIMENSION(:), INTENT(in)      :: py   !! Vector containing the  
     3136                                              !! previous values of px 
     3137                                              !! Warning : due to memory  
     3138                                              !! optimization, we have 
     3139                                              !! generally SIZE(px) /= SIZE(py)   
     3140  INTEGER, INTENT(in)                 :: pwx  !! Used to calculate average value                              
     3141 
     3142  !! 0.3 Modified variables 
     3143 
     3144  REAL, DIMENSION(:), INTENT(inout)   :: px   !! Result 
     3145 
     3146  !! 0.4 Local variables 
     3147 
     3148  INTEGER :: ig                               !! Index 
     3149 
     3150!--------------------------------------------------------------------- 
     3151 
     3152  !! Perform operations only if the values of ind don't exceed the size of px  
     3153 
     3154  IF ( MAXVAL(ind) > SIZE(px) ) THEN 
     3155     CALL ipslerr(3,"moycum_index", & 
     3156          & "the index vector is out of range for px", & 
     3157          & "Indexation vector problem. We stop", " " ) 
     3158  END IF 
     3159 
     3160  IF (pwx /= 0) THEN 
     3161     IF      (opp == 'ave') THEN 
     3162        DO ig = 1,nbi 
     3163           px(ind(ig)) = (px(ind(ig))*pwx + py(ind(ig)))/REAL(pwx+1) 
     3164        END DO 
     3165     ELSE IF (opp == 't_sum') THEN 
     3166        DO ig = 1,nbi 
     3167           px(ind(ig)) = px(ind(ig)) + py(ind(ig)) 
     3168        END DO 
     3169     ELSE IF ( (opp == 'l_min').OR.(opp == 't_min') ) THEN 
     3170        DO ig = 1,nbi 
     3171           px(ind(ig)) = MIN(px(ind(ig)),py(ind(ig))) 
     3172        END DO 
     3173     ELSE IF ( (opp == 'l_max').OR.(opp == 't_max') ) THEN 
     3174        DO ig = 1,nbi 
     3175           px(ind(ig)) = MAX(px(ind(ig)),py(ind(ig))) 
     3176        END DO 
     3177     ELSE 
     3178        CALL ipslerr(3,"moycum_index",'Unknown time operation',opp,' ') 
     3179     END IF 
     3180  ELSE 
     3181    IF      (opp == 'l_min') THEN 
     3182       DO ig = 1,nbi 
     3183          px(ind(ig)) = MIN(px(ind(ig)),py(ind(ig))) 
     3184       END DO 
     3185    ELSE IF (opp == 'l_max') THEN 
     3186       DO ig = 1,nbi 
     3187          px(ind(ig)) = MAX(px(ind(ig)),py(ind(ig))) 
     3188       END DO 
     3189    ELSE 
     3190       DO ig = 1,nbi 
     3191          px(ind(ig)) = py(ind(ig)) 
     3192       END DO 
     3193    ENDIF 
     3194 END IF 
     3195 
     3196END SUBROUTINE moycum_index 
     3197 
     3198 
    31213199!----------------- 
    31223200END MODULE mathelp 
Note: See TracChangeset for help on using the changeset viewer.