爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 3205|回复: 7

[源代码] Li Jianping老师的 ROF 程序中错误已经修改好,两行红色表示修改之处!

[复制链接]

新浪微博达人勋

发表于 2013-12-16 16:51:55 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
      Li Jianping老师的ROF程序中错误已经修改好,两行红色表示修改之处!
子程序REOF.f 如下,欢迎调用


CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
C ***********Li Jianping老师的ROF程序中错误已经修改好,两行红色表示修改之处***********C
C  A. STATISTICAL ANALYSIS                                             C
C     8  EMPIRICAL ORTHOGONAL FUNCTIONS (EOF'S) AND                    C
C        ROTATED EMPIRICAL ORTHOGONAL FUNCTIONS (REOF'S)               C
C        (1) REOF                                                      C
C        (2) TRANSF                                                    C
C        (3) CROSSPRODUCT                                              C
C        (4) JCB                                                       C
C        (5) ARRANG                                                    C
C        (6) TCOEFF                                                    C
C        (7) ROTATOR                                                   C
C        (8) ARRANGE2                                                  C     
C        (9) MEANVAR                                                   C
C        (10)INITIAL                                                   C
C                                                                      C
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
C
C     BY DR. JIANPING LI AND DONG XIAO, JUL. 17, 2006.
C
!*****TIME-SPACE TRANSFERMATION IS USED FOR SAVING CALCULATIONAL TIME.
C     THE MISSING VALUES (TERRAIN), ANNUAL CYCLE AND THE GRIDS WHOSE VARIANCE
C     EQUAL TO ZERO ARE REMOVED (ADDED) BEFORE (AFTER) CALLING THE SUBROUTINE.   
C
C     REFERENCE: 《METHODS FOR DIAGNOSING AND FORECASTING CLIMATE VARIABILITY?
C     BY HONGBAO WU AND LEI WU, PUBLISHED IN 2005. CHINA METOROLOGY PRESS.
C
C     QUESTIONS, SUGGESTIONS OR GS FILE FOR DRAWING PICTURES? EMIAL US, PLEASE!
C     E-MAIL: LJP@LASG.IAP.AC.CN, XIAODONG@MAIL.IAP.AC.CN.
C
C     CITATION: LI, J., AND D. XIAO, 2006: REOF SUBROUTINE, HTTP://WEB.LASG.AC.CN/STAFF/LJP/SUBROUTINE/REOF.F.
C
C-----*----------------------------------------------------6---------7--
C
C     WARNING: THE STACKS OF THIS SUBROUTINE MAY OVERFLOW IN PERSONAL COMPUTER (PC).
C       IF YOU WANT TO COMPUTE IT ON PC, PLEASE DELETE THE EXPRESSIONS '*4'
C       IN 68, 174, 181, 186 AND 193, AND GO ON.
C
C     THE PARAMETERS YOU NEED TO CHANGE:   
C         N---LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE;
C       MX---GRIDS IN ROW;
C       MY---GRIDS IN COLUMN;
C       MNL---MIN(M,N)
C       NP---NUM. OF EIGENVECTORS TO ROTATE;
C       UNDEF---MISSING VALUE;
C       MG1 AND MG2---THE EFFICIENT GRIDS (OUTPUT ON SCREEN) AND CANCEL THE
C           "STOP" IN LINE 111, TRY AGAIN.
C       KS=-1,0,1: SEE THE CAPTION OF THE REOF SUBROUTINE.
C       KM=1: MONTHLY OR DAILY DATA. KM=0: DATA WITHOUT ANNUAL CYCLE.
C       ND: THE NUMBER OF THE MONTHS OR DAYS IN A YEAR.
C   
C-----*----------------------------------------------------6---------7--
      PROGRAM MAIN
PARAMETER(N=722,MX=9,MY=9,M=MX*MY,MNL=M,NP=10)
PARAMETER(UNDEF=32767.0,MG1=81,MG2=81)
      PARAMETER(KS=0,KM=1,ND=12,STD=0.0001)
!-----INPUT ARRAY
      DIMENSION F0(N,M)
!-----WORK ARRAYS
      DIMENSION F1(N,MG1),F2(N,MG1),G(MG1),H1(MG1,N),H2(MG1,N)
DIMENSION F(MG2,N),GVT(MG2,MNL),RGVT(MG2,NP),COF(MNL,N),RCOF(NP,N)
!-----OUTPUT ARRAYS
      DIMENSION ER(MNL,4),EGVT(M,MNL),ECOF(MNL,N)
      DIMENSION RER(NP,2),REGVT(M,NP),RECOF(NP,N)


C-----READ DATA.
      OPEN(20,FILE='SST.DAT',STATUS='UNKNOWN'
     &,FORM='UNFORMATTED',ACCESS='DIRECT',RECL=M)
         DO J=1,N
READ(20,REC=J)(F0(J,I),I=1,M)
         END DO
CLOSE(20)
WRITE(*,*)'READ DATA OK'
C-----REMOVE THE TERRAIN OR MISSING VALUE.
      L1=0
DO J=1,M
IF(F0(1,J).NE.UNDEF)THEN
          L1=L1+1
   DO K=1,N
            F1(K,L1)=F0(K,J)
   ENDDO
ENDIF
ENDDO
      WRITE(*,*)'GRIDS WITHOUT TERRAIN'
WRITE(*,*)'MG1=',L1
C-----REMOVE ANNUAL CYCLE.
      IF(KM.EQ.1)THEN
NY=N/ND         
DO I=1,L1
   CALL INITIAL(ND,NY,N,F1(1,I),F2(1,I))
END DO
DO I=1,L1
   DO K=1,N
     F1(K,I)=F2(K,I)
   END DO
END DO
END IF
C-----REMOVE THE GRIDS WHOSE VARIANCE EQUAL TO ZERO.
L2=0
DO I=1,L1
CALL MEANVAR(N,F1(1,I),AX,G(I),VX)
IF(G(I).GT.STD)THEN
          L2=L2+1
   DO K=1,N
            F(L2,K)=F1(K,I)
   ENDDO
ENDIF
END DO
WRITE(*,*)'GRIDS WITHOUT TERRAIN AND CONSTANT VALUE'
WRITE(*,*)'MG2=',L2
STOP
C-----CALL THE SUBROUTINE.
      CALL REOF(L2,N,MNL,NP,F,KS,ER,GVT,ECOF,RER,RGVT,RECOF)
WRITE(*,*)'REOF OK AND TRANSFORM TO THE ORIGINAL FORM IN THE NEXT'
C-----ADD THE GRIDS WHOSE VARIANCE EQUAL TO ZERO.      
L3=0
DO I=1,MG2
IF(G(I).GT.STD)THEN
   L3=L3+1
   DO K=1,MNL
     H1(I,K)=GVT(L3,K)
   END DO
   DO K=1,NP
     H2(I,K)=RGVT(L3,K)
   END DO
ELSE
   DO K=1,MNL
     H1(I,K)=UNDEF
   END DO
   DO K=1,NP
     H2(I,K)=UNDEF
   END DO
ENDIF
ENDDO
C-----ADD THE TERRAIN OR MISSING VALUE.
L4=0
DO I=1,M
IF(F0(1,I).NE.UNDEF)THEN
   L4=L4+1
   DO K=1,MNL
     EGVT(I,K)=H1(L4,K)
   END DO
DO K=1,NP
     REGVT(I,K)=H2(L4,K)
   END DO
ELSE
   DO K=1,MNL
     EGVT(I,K)=UNDEF
   END DO
   DO K=1,NP
     REGVT(I,K)=UNDEF
   END DO
ENDIF
ENDDO
C-----OUTPUT THE RESULT.        
C-----OUTPUT THE ERROR.
      WRITE(*,*)'OUTPUT THE RESULTS'
OPEN(10,FILE='ER.DAT',STATUS='UNKNOWN')
      WRITE(10,*)'EOF LAMDA (EIGENVALUES) FROM BIG TO SMALL'
WRITE(10,*)(ER(I,1),I=1,MNL)
WRITE(10,*)'EOF ACCUMULATED EIGENVALUES FROM BIG TO SMALL'
WRITE(10,*)(ER(I,2),I=1,MNL)
WRITE(10,*)'EOF EXPLAINED VARIANCES'
WRITE(10,*)(ER(I,3),I=1,MNL)
WRITE(10,*)'EOF ACCUMULATED EXPLAINED VARIANCES'
WRITE(10,*)(ER(I,4),I=1,MNL)
WRITE(10,*)'REOF EXPLAINED VARIANCES'
WRITE(10,*)(RER(I,1)/N**2,I=1,NP)
WRITE(10,*)'REOF ACCUMULATED EXPLAINED VARIANCES'
WRITE(10,*)(RER(I,2)/N**2,I=1,NP)
CLOSE(10)
C-----OUTPUT EIGENVACTORS MATRIX OF EOF.
      OPEN(11,FILE='EGVT.DAT',STATUS='UNKNOWN'
     &,FORM='UNFORMATTED',ACCESS='DIRECT',RECL=MX*MY)
DO J=1,MNL
WRITE(11,REC=J)(EGVT(I,J),I=1,M)
END DO
CLOSE(11)
C-----OUTPUT TIME COEFFICIENTS MATRIX OF EOF.
      OPEN(12,FILE='ECOF.DAT',STATUS='UNKNOWN'
     &,FORM='UNFORMATTED',ACCESS='DIRECT',RECL=MNL)
      DO I=1,N
WRITE(12,REC=I)(ECOF(J,I),J=1,MNL)
END DO
CLOSE(12)
C-----OUTPUT LOADING VECTORS OF REOF.
      OPEN(13,FILE='REGVT.DAT',STATUS='UNKNOWN'
     &,FORM='UNFORMATTED',ACCESS='DIRECT',RECL=MX*MY)
      DO J=1,NP
WRITE(13,REC=J)(REGVT(I,J),I=1,M)
END DO
CLOSE(13)
C-----OUTPUT TIME COEFFICIENTS MATRIX OF REOF.
      OPEN(14,FILE='RECOF.DAT',STATUS='UNKNOWN'
     &,FORM='UNFORMATTED',ACCESS='DIRECT',RECL=NP)
      DO J=1,N
        WRITE(14,REC=J)(RECOF(I,J),I=1,NP)
END DO
CLOSE(14)
C-----
END
C-----*----------------------------------------------------6---------7--
C     ROTATED EMPERICAL ORTHOGONAL FUNCTION (REOF)
C     THIS SUBROUTINE APPLIES THE REOF APPROACH TO ANALYSIS
C       TIME SERIES OF METEOROLOGICAL FIELD F(M,N).
C
C     INPUT: M,N,MNL,NP,F(M,N),KS
C       M: NUMBER OF GRID-POINTS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       MNL=MIN(M,N)
C       NP: THE NUMBER OF THE EIGENVACTORS TO ROTATE
C         (THE CORRESPONDING EOF ACCUMULATED VARIANCE IS ABOUT 60-80% OR THE
C         CORRESPONDING EIGENVALUES OF EOF EXCEED 1.0 )
C       F(M,N): THE RAW SPATIAL-TEMPORAL SEIRES
C       KS: CONTRAL PARAMETER
C           KS=-1: SELF; KS=0: DEPATURE; KS=1: STANDERLIZED DEPATURE
C       SELF: GENERALLY NOT BE ADAPTED, THE FIRST MODES LIKE THE CLIMATE NORMAL.
C           THE OTHERS ARE SAME AS THE MODES OF DEPARTURE FIELD.
C       DEPARTURE: THE EIGENVECTORS STAND FOR THE AVERAGED ANOMALIES OF THE VARIABLE.
C           THE LARGER THE ANOMALIES, THE MORE THE CONTRIBUTION.
C           IT WOULD EMPHASIZE THE REGIONS WITH LARGER ANOMALIES.
C           SUGGESTION: MAINLY USED IN LARGER SCALE FIELD.
C  STANDARD: THE EIGENVECTORS STAND FOR THE CORRELATION COEFFICIENTS
C           BETWEEN THE TIMESERIES OF THE GRIDS AND THE CORRESPONDING TIME COEFFICIENTS.
C           STANDARD=DEPARTURE/(STANDARD DEVIATION). IT COMPUTE EVERY GRID IN SAME LEVEL.
C           THERE IS NO REGIONAL DIFFERENCE IN THIS KIND FIELD.
C           SUGGESTION: MAINLY USED IN THE CORRELATIONS OF DIFFERENT REGIONS.
C
C     OUTPUT: EGVT,ECOF,ER,RER,REGVT,RECOF
C       EGVT(M,MNL): ARRAY OF EIGENVACTORS
C       ECOF(MNL,N): ARRAY OF TIME COEFFICIENTS FOR THE RESPECTIVE EIGENVECTORS
C       ER(MNL,1): LAMDA (EIGENVALUES), ITS EQUENCE IS FROM BIG TO SMALL.
C       ER(MNL,2): ACCUMULATED EIGENVALUES FROM BIG TO SMALL
C       ER(MNL,3): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN) FROM BIG TO SMALL
C       ER(MNL,4): ACCUMULATED EXPLAINED VARIANCES FROM BIG TO SMALL
C       RER(MNL,1): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN)
C       RER(MNL,2): ACCUMULATED EXPLAINED VARIANCES
C       REGVT(M,NP): RODATED ARRAY OF LOADING VECTORS OF REOF
C       RECOF(MNL,NP): RODATED ARRAY OF TIME COEFFICIENTS FOR THE RESPECTIVE EIGENVECTORS
C
C     BY DONG XIAO AND DR. JIANPING LI, JUL. 17, 2006
C     RECMOPLIED ON MAY 9, 2007
C
C     REFERENCE: 《METHODS FOR DIAGNOSING AND FORECASTING CLIMATE VARIABILITY?
C     BY HONGBAO WU AND LEI WU, PUBLISHED IN 2005. CHINA METOROLOGY PRESS.
C-----
      SUBROUTINE REOF(M,N,MNL,NP,F,KS,ER,EGVT,ECOF,RER,REGVT,RECOF)
!-----INPUT ARRAY
      DIMENSION F(M,N)
!-----WORK ARRAYS
      DIMENSION COV(MNL,MNL),S(MNL,MNL),D(MNL)
!-----OUTPUT ARRAYS
      DIMENSION ER(MNL,4),EGVT(M,MNL),ECOF(MNL,N)
      DIMENSION RER(NP,2),REGVT(M,NP),RECOF(NP,N)




C---- PREPROCESSING DATA
      CALL TRANSF(M,N,F,KS)
C---- CROSSED PRODUCT MATRIX OF THE DATA F
      CALL CROSSPRODUCT(M,N,MNL,F,COV,SUM)
C---- EIGENVALUES AND EIGENVECTORS BY THE JACOBI METHOD
      EPS=1E-7
      CALL JCB(MNL,COV,S,D,EPS)
C---- SPECIFIED EIGENVALUES
      CALL ARRANG(M,N,MNL,D,S,ER,TR)
WRITE(*,*)'ERROR=',SUM-TR
C---- NORMALIZED EIGNVECTORS AND THEIR TIME COEFFICIENTS
      CALL TCOEFF(M,N,MNL,F,S,ER,EGVT,ECOF)
WRITE(*,*)'EOF ACCOMPLISHED'
C-----LINEAR TRANSPOSED (ROTATE)
      CALL ROTAOR(M,N,MNL,NP,EGVT,ECOF,TR,RER,REGVT,RECOF)
WRITE(*,*)'REOF ACCOMPLISHED'
C---- SPECIFIED EIGNVECTORS AND TIME COEFFICIENTS WITH EXPLAINED VARIANCES OF REOF (IF YOU NEED)     
      CALL ARRANGE2(M,N,NP,REGVT,RECOF,RER)
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     PREPROCESSING DATA TO PROVIDE A FIELD BY KS.
C
C     INPUT: M,N,F,KS
C       M: NUMBER OF GRID-POINTS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       F(M,N): THE RAW SPATIAL-TEMPORAL SEIRES
C       KS: CONTRAL PARAMETER
C           KS=-1: SELF; KS=0: DEPATURE; KS=1: STANDERDLIZED DEPATURE
C
C     OUTPUT: F
C       F(M,N): OUTPUT FIELD BASED ON THE CONTROL PARAMETER KS.
C
C     BY DR. JIANPING LI.
C-----
      SUBROUTINE TRANSF(M,N,F,KS)
!-----INPUT ARRAY
      DIMENSION F(M,N)
!-----WORK ARRAYS
      DIMENSION FW(N),WN(M)


I0=0
DO I=1,M
DO J=1,N
          FW(J)=F(I,J)
        ENDDO
CALL MEANVAR(N,FW,AF,SF,VF)
IF(SF.EQ.0.)THEN
   I0=I0+1
   WN(I0)=I
ENDIF
ENDDO
IF(I0.NE.0)THEN
WRITE(*,*)'****  FAULT  ****'
WRITE(*,*)' THE PROGRAM CANNOT GO ON BECAUSE THE ORIGINAL FIELD'
        WRITE(*,*)'     HAS INVALID DATA WHOSE VARIANCE EQUAL ZERO.'
WRITE(*,*)
WRITE(*,*)' THERE ARE TOTALLY',I0,'       GRIDPIONTS
     *WITH INVALID DATA.'
WRITE(*,*)
              WRITE(*,*)' THE ARRAY WN STORES THE POSITIONS OF THOSE INVALID '
        WRITE(*,*)'     GRID-POINTS. YOU MUST PICK OFF THOSE INVALID '  
        WRITE(*,*)'     DATA FROM THE ORIGNAL FIELD AND THEN REINPUT '  
        WRITE(*,*)'     A NEW FIELD TO CALCULATE ITS EOFS.'   
WRITE(*,*)'****  FAULT  ****'
STOP
ENDIF         
      IF(KS.EQ.-1)RETURN
C-----ANOMALY OF F
      IF(KS.EQ.0)THEN               
        DO I=1,M
          DO J=1,N
            FW(J)=F(I,J)
          ENDDO
          CALL MEANVAR(N,FW,AF,SF,VF)
          DO J=1,N
            F(I,J)=F(I,J)-AF
          ENDDO
        ENDDO
        RETURN
      ENDIF
C-----NORMALIZING F
      IF(KS.EQ.1)THEN                 
        DO I=1,M
          DO J=1,N
            FW(J)=F(I,J)
          ENDDO
          CALL MEANVAR(N,FW,AF,SF,VF)
          DO J=1,N
            F(I,J)=(F(I,J)-AF)/SF
          ENDDO
        ENDDO
      ENDIF
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     CROSSED PRODUCT MARTIX OF THE DATA. IT IS N TIMES OF
C       COVARIANCE MATRIX OF THE DATA IF KS=0 (I.E. FOR ANOMALY).
C
C     INPUT: M,N,MNL,F
C       M: NUMBER OF GRID-POINTS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       MNL=MIN(M,N)
C       F(M,N): THE RAW SPATIAL-TEMPORAL SEIRES
C
C     OUTPUT: COV(MNL,MNL),SUM  
C       COV(M,N)=(F*F') OR (F'F) DEPENDES ON M AND N.
C         IT IS A MNL*MNL REAL SYMMETRIC MATRIX.
C       SUM: THE TRA OF THE MATRIX (F*F')/N
C
C     BY DR. JIANPING LI.
C     RECOMPILED BY DONG XIAO, JUL. 17, 2006
C-----
      SUBROUTINE CROSSPRODUCT(M,N,MNL,F,COV,SUM)
!-----INPUT ARRAY
      DIMENSION F(M,N)
!-----WORK ARRAY
DIMENSION COV(MNL,MNL)


      IF(N-M) 10,50,50
  10  DO 20 I=1,MNL
      DO 20 J=I,MNL
        COV(I,J)=0.0
        DO IS=1,M
          COV(I,J)=COV(I,J)+F(IS,I)*F(IS,J)
        ENDDO
        COV(J,I)=COV(I,J)
  20  CONTINUE
      SUM=0.
DO I=1,MNL
SUM=SUM+COV(I,I)
END DO
SUM=SUM/(MNL*1.)
      RETURN
  50  DO 60 I=1,MNL
      DO 60 J=I,MNL
        COV(I,J)=0.0
        DO JS=1,N
          COV(I,J)=COV(I,J)+F(I,JS)*F(J,JS)
        ENDDO
        COV(J,I)=COV(I,J)
  60  CONTINUE
      SUM=0.
DO I=1,MNL
SUM=SUM+COV(I,I)
END DO
SUM=SUM/(MNL*1.)
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     COMPUTING EIGENVALUES AND EIGENVECTORS OF A REAL SYMMETRIC MATRIX
C       A(M,M) BY THE JACOBI METHOD
C
C     INPUT: M,A,S,D,EPS
C       M: ORDER OF MATRIX
C       A(M,M): THE COVARIANCE MATRIX
C       EPS: GIVEN PRECISION
C
C     OUTPUT: S,D
C       S(M,M): EIGENVECTORS
C       D(M): EIGENVALUES
C
C     BY DR. JIANPING LI.
C-----
      SUBROUTINE JCB(M,A,S,D,EPS)
!-----INPUT ARRAY
      DIMENSION A(M,M)
!-----OUTPUT ARRAYS
DIMENSION S(M,M),D(M)


      DO 30 I=1,M
      DO 30 J=1,I
        IF(I-J) 20,10,20
  10    S(I,J)=1.
        GO TO 30
  20    S(I,J)=0.
        S(J,I)=0.
  30  CONTINUE
      G=0.
      DO 40 I=2,M
        I1=I-1
        DO 40 J=1,I1
  40      G=G+2.*A(I,J)*A(I,J)
      S1=SQRT(G)
      S2=EPS/FLOAT(M)*S1
      S3=S1
      L=0
  50  S3=S3/FLOAT(M)
  60  DO 130 IQ=2,M
        IQ1=IQ-1
        DO 130 IP=1,IQ1
        IF(ABS(A(IP,IQ)).LT.S3) GOTO 130
        L=1
        V1=A(IP,IP)
        V2=A(IP,IQ)
        V3=A(IQ,IQ)
        U=0.5*(V1-V3)
        IF(U.EQ.0.0) G=1.
        IF(ABS(U).GE.1E-10) G=-SIGN(1.,U)*V2/SQRT(V2*V2+U*U)
        ST=G/SQRT(2.*(1.+SQRT(1.-G*G)))
        CT=SQRT(1.-ST*ST)
        DO 110 I=1,M
          G=A(I,IP)*CT-A(I,IQ)*ST
          A(I,IQ)=A(I,IP)*ST+A(I,IQ)*CT
          A(I,IP)=G
          G=S(I,IP)*CT-S(I,IQ)*ST
          S(I,IQ)=S(I,IP)*ST+S(I,IQ)*CT
  110     S(I,IP)=G
        DO 120 I=1,M
          A(IP,I)=A(I,IP)
  120     A(IQ,I)=A(I,IQ)
        G=2.*V2*ST*CT
        A(IP,IP)=V1*CT*CT+V3*ST*ST-G
        A(IQ,IQ)=V1*ST*ST+V3*CT*CT+G
        A(IP,IQ)=(V1-V3)*ST*CT+V2*(CT*CT-ST*ST)
        A(IQ,IP)=A(IP,IQ)
  130 CONTINUE
      IF(L-1) 150,140,150
  140 L=0
      GO TO 60
  150 IF(S3.GT.S2) GOTO 50
      DO 160 I=1,M
        D(I)=A(I,I)
  160 CONTINUE
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     PROVIDES A SERIES OF EIGENVALUES FROM MAXIMUIM TO MINIMUIM.
C
C     INPUT: M,N,MNL,D,S
C       M: NUMBER OF GRID-POINTS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       D(MNL): EIGENVALUES
C       S(MNL,MNL): EIGENVECTORS
C
C     OUTPUT: ER,TR
C       ER(MNL,1): LAMDA (EIGENVALUES), ITS EQUENCE IS FROM BIG TO SMALL.
C       ER(MNL,2): ACCUMULATED EIGENVALUES FROM BIG TO SMALL
C       ER(MNL,3): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN) FROM BIG TO SMALL
C       ER(MNL,4): ACCUMULATED EXPLANED VARIANCES FROM BIG TO SMALL
C       TR: THE TRA OF THE EIGENVECTORS MATRIX.
C
C     BY DR. JIANPING LI.
C-----
      SUBROUTINE ARRANG(M,N,MNL,D,S,ER,TR)
!-----INPUT ARRAYS
      DIMENSION D(MNL),S(MNL,MNL)
!-----OUTPUT ARRAY
DIMENSION ER(MNL,4)


TR=0.0
      DO 10 I=1,MNL
        TR=TR+D(I)/(MNL*1.)
        ER(I,1)=D(I)/(MNL*1.)
  10  CONTINUE
      MNL1=MNL-1
      DO 20 K1=MNL1,1,-1
      DO 20 K2=K1,MNL1
        IF(ER(K2,1).LT.ER(K2+1,1)) THEN
          C=ER(K2+1,1)
          ER(K2+1,1)=ER(K2,1)
          ER(K2,1)=C
          DO 15 I=1,MNL
            C=S(I,K2+1)
            S(I,K2+1)=S(I,K2)
            S(I,K2)=C
  15      CONTINUE
        ENDIF
  20  CONTINUE
      ER(1,2)=ER(1,1)
      DO 30 I=2,MNL
        ER(I,2)=ER(I-1,2)+ER(I,1)
  30  CONTINUE
      DO 40 I=1,MNL
        ER(I,3)=ER(I,1)*100./TR
        ER(I,4)=ER(I,2)*100./TR
  40  CONTINUE
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     PROVIDES EIGENVECTORS AND THEIR TIME COEFFICIENTS
C
C     INPUT: M,N,MNL,F,S,ER
C       M: NUMBER OF GRID-POINTS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       MNL=MIN(M,N)
C       F(M,N): THE RAW SPATIAL-TEMPORAL SEIRES
C       S(MNL,MNL): EIGENVECTORS
C       ER(MNL,1): LAMDA (EIGENVALUES), ITS EQUENCE IS FROM BIG TO SMALL.
C       ER(MNL,2): ACCUMULATED EIGENVALUES FROM BIG TO SMALL.
C       ER(MNL,3): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN) FROM BIG TO SMALL.
C       ER(MNL,4): ACCUMULATED EXPLANED VARIANCES FROM BIG TO SMALL.
C
C     OUTPUT: EGVT,ECOF
C       EGVT(M,MNL): NEW EIGENVECTORS
C         DEPARTURE: THE EIGENVECTORS STAND FOR THE SWING OF THE VARIABLE.
C    STANDARD: THE EIGENVECTORS STAND FOR THE CORRELATION COEFFICIENTS
C           BETWEEN THE TIMESERIES AND THE CORRESPONDING TIME COEFFICIENTS.
C       ECOF(MNL,N): TIME COEFFICIENTS OF EGVT
C
C     BY DR. JIANPING.LI
C     RECOMPILED BY DONG XIAO, JUL. 17, 2006
C-----
      SUBROUTINE TCOEFF(M,N,MNL,F,S,ER,EGVT,ECOF)
!-----INPUT ARRAYS
      DIMENSION F(M,N),S(MNL,MNL),ER(MNL,4)
!-----WORK ARRAYS
      DIMENSION V(M),V1(N)
!-----OUTPUT ARRAYS
DIMENSION EGVT(M,MNL),ECOF(MNL,N)


      DO J=1,MNL
        DO I=1,M
          EGVT(I,J)=0.
        ENDDO
        DO I=1,N
          ECOF(J,I)=0.
        ENDDO
      ENDDO
C-----NORMALIZING THE INPUT EIGNVECTORS (C=SQRT(LAMDA))
      DO 10 J=1,MNL
        C=0.
        DO I=1,MNL
          C=C+S(I,J)*S(I,J)
        ENDDO
        C=SQRT(C)
        DO I=1,MNL
          S(I,J)=S(I,J)/C
        ENDDO
  10  CONTINUE
C-----(M<N)
      IF(M.LE.N) THEN      
DO JS=1,MNL
          DO I=1,M
            EGVT(I,JS)=S(I,JS)
          ENDDO
        ENDDO
        DO 30 J=1,N
          DO I=1,M
            V(I)=F(I,J)
          ENDDO
          DO IS=1,MNL
            DO I=1,M
              ECOF(IS,J)=ECOF(IS,J)+V(I)*EGVT(I,IS)
            ENDDO
          ENDDO
  30    CONTINUE
      ELSE
C-----(M>N)
        DO 40 I=1,M
          DO J=1,N
            V1(J)=F(I,J)
          ENDDO
          DO JS=1,MNL
          DO J=1,N
            EGVT(I,JS)=EGVT(I,JS)+V1(J)*S(J,JS)
          ENDDO
          ENDDO
  40    CONTINUE
        DO 60 J=1,N
          DO I=1,M
            V(I)=F(I,J)
          ENDDO
!-----Z=V'(N*M)X(M*N)-------NOT BE ADOPTED, NEED TO BE NOMORALIZED AGAIN.
C          DO IS=1,MNL
C            DO I=1,N
C              ECOF(IS,J)=ECOF(IS,J)+V(I)*EGVT(I,IS)
C            ENDDO
C          ENDDO
  60    CONTINUE
C-----Z=V'SQRT(LAMDA)---(Z=V'X=>ZV=V'XV=V'(LAMDA*V)=(LAMDA*V')V=>Z=LAMDA*V' OR V=0)
C     THE LAMDA HERE IS 1/N TIMES OF THAT IN THE REFERENCE.
        DO 50 JS=1,MNL
          DO J=1,N
            ECOF(JS,J)=S(J,JS)*SQRT(ABS(ER(JS,1))/(MNL*1.0))
          ENDDO
          DO I=1,M
            EGVT(I,JS)=EGVT(I,JS)/SQRT(ABS(ER(JS,1))/(MNL*1.0))
          ENDDO
  50    CONTINUE
C-----TRANSFER NORMALIZED EIGENVECTORS AND TIME COEFFICIENTS TO NEW ONES
C     FOR NEW MEANS:
C       DEPARTURE: THE EIGENVECTORS STAND FOR THE SWING OF THE VARIABLE.
C  STANDARD: THE EIGENVECTORS STAND FOR THE CORRELATION COEFFICIENTS
C         BETWEEN THE TIMESERIES AND THE CORRESPONDING TIME COEFFICIENTS.
      DO JS=1,MNL
DO I=1,M
          EGVT(I,JS)=EGVT(I,JS)*(SQRT(ABS(ER(JS,1))))
END DO
DO I=1,N
   ECOF(JS,I)=(ECOF(JS,I))/(SQRT(ABS(ER(JS,1))))
END DO
END DO
END IF
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     COMPUTING EIGENVALUES AND EIGENVECTORS OF A REAL SYMMETRIC MATRIX
C       A(M,N) BY THE ROTATED METHOD
C
C     INPUT: M,N,MNL,NP,EGVT,ECOF,TR
C       M: GRIDS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       MNL=MIN(M,N)
C       NP: NUM. OF EIGENVECTORS TO ROTATE
C       EGVT(M,N): THE EIGENVACTORS MATRIX
C       TR: THE RANK OF THE EIGENVECTORS MATRIX
C
C     OUTPUT: REGVT,RECOF,RER
C       REGVT(M,NP): THE ROTATED ARRAY OF EIGENVACTORS (LOADING VECTOR)
C       RECOF(NP,N): ARRAY OF TIME COEFFICIENTS FOR THE RESPECTIVE EIGENVECTORS
C       RER(MNL,1): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN)
C       RER(MNL,2): ACCUMULATED EXPLAINED VARIANCES
C
C     REFERENCE: 《METHODS FOR DIAGNOSING AND FORECASTING CLIMATE VARIABILITY?
C       BY HONGBAO WU AND LEI WU, PUBLISHED IN 2005. CHINA METOROLOGY PRESS.
C
C     BY PROF. HONGBAO WU
C     BECOMPILED BY DONG XIAO, JULY 17, 2006
C-----
SUBROUTINE ROTAOR(M,N,MNL,NP,EGVT,ECOF,TR,RER,REGVT,RECOF)
!-----INPUT ARRAYS
DIMENSION EGVT(M,MNL),ECOF(MNL,N)         
!-----WORK ARRAYS
DIMENSION H(M),ST(NP),VRLV(500),ER(MNL,4),S(M,NP)
!-----OUTPUT ARRAYS         
      DIMENSION REGVT(M,NP),RECOF(NP,N),RER(NP,2)
      INTEGER T,K


      WRITE(*,*)'ROTATE BEGINNING'
C-----TAKE OUT FORWARD NP EIGENVECTORS TO ROTATE
      DO J=1,NP
        DO I=1,M
   REGVT(I,J)=EGVT(I,J)
END DO
END DO
C-----TAKE OUT FORWARD NP TIME COEFFICIENTS TO ROTATE
      DO I=1,NP
        DO J=1,N
RECOF(I,J)=ECOF(I,J)
        END DO
END DO
C-----COMPUTE THE COMMON DEGREE
      DO I=1,M
H(I)=0.0
        DO J=1,NP
         H(I)=H(I)+REGVT(I,J)**2
        END DO
END DO
      DO I=1,M
H(I)=SQRT(H(I))
      END DO
C-----COMPUTE THE VARIANCE OF THE VARIANCE CONTRIBUTION BY PER COMMON DEGREE
C-----(EQUAL TO THE RATATED ONE)
      VRLV0=0.0
      DO K=1,NP
G1=0.0
        G2=0.0
        DO I=1,M
G1=G1+(REGVT(I,K)**2/H(I)**2)**2/REAL(M)
G2=G2+(REGVT(I,K)**2/H(I)**2)/REAL(M)
        END DO
G2=G2**2
VRLV0=VRLV0+G1-G2
      END DO
C-----ROTATED
      LLL=0
WRITE(*,*)'ROTATE TIMES'
800  CONTINUE
      DO 505 T=1,NP
      DO 505 K=1,NP
        IF(T.GE.K) GOTO 505
CALL ROT(REGVT,RECOF,H,T,K,M,N,NP)
505  CONTINUE
      LLL=LLL+1
WRITE(*,*)'LLL=',LLL
      VRLV(LLL)=0.0
      DO K=1,NP
G1=0.0
G2=0.0
        DO I=1,M
   G1=G1+(REGVT(I,K)**2/H(I)**2)**2/REAL(M)
            G2=G2+(REGVT(I,K)**2/H(I)**2)/REAL(M)
        END DO
G2=G2**2
VRLV(LLL)=VRLV(LLL)+G1-G2
      END DO
      IF(LLL.LT.2) GOTO 800
CI=(VRLV(LLL)-VRLV(LLL-1))/VRLV0
IF(CI.LT.0.001) GOTO 600
IF(LLL.GE.100) GOTO 600
      GOTO 800
600  CONTINUE
C-----COMPUTE THE EXPLAINED VARIANCES
DO J=1,NP
ST(J)=0.0
        DO I=1,M
         ST(J)=ST(J)+REGVT(I,J)**2
        END DO
      END DO
      DO J=1,NP
RER(J,1)=ST(J)*100/TR
END DO
C-----COMPUTE THE ACCUMULATED EXPLAINED VARIANCES
      DDD=0.0
      DO K=1,NP
        DDD=DDD+ST(K)/TR
        RER(K,2)=DDD*100.
      ENDDO
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     COMPUTING EIGENVALUES AND EIGENVECTORS OF TWO COLUMNS OF
C       A(M,T) AND A(M,K) BY THE ROTATED METHOD
C
C     INPUT: A,B,H,T,K,MM,NN,NP
C       A(M,NP): THE COVARIANCE MATRIX
C       B(NP,N): THE TIME COEFFICIENT MATRIX
C       H(M): COMMON DEGREE.
C       T: COLUMN 1 (GRID 1)
C       K: COLUMN 2 (GRID 2)
C       M: GRIDS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       NP: NUM. OF EIGENVECTORS TO ROTATE
C
C     OUTPUT: A,B
C       A(M,NP): THE ROTATED COVARIANCE MATRIX
C       B(NP,N): TIME COEFFICIENT MATRIX
C
C     BY PROF. HONGBAO WU
C     BECOMPILED BY DONG XIAO, JUL 17, 2006
C-----
      SUBROUTINE ROT(A,B,H,T,K,M,N,NP)
!-----INPUT ARRAYS
      DIMENSION A(M,NP),B(NP,N),H(M)
!-----WORK ARRAYS
      DIMENSION U(M),VR(M),WT(M),WK(M),WBT(N),WBK(N)
!-----OUTPUT ARRAYS
C      DIMENSION A(M,NP),B(NP,N)
      INTEGER T,K


C-----COMPUTE FI
      DO 25 I=1,M
      U(I)=(A(I,T)/H(I))**2-(A(I,K)/H(I))**2
25   VR(I)=2.0*(A(I,T)/H(I))*(A(I,K)/H(I))
      C=0.0
      D=0.0
      S=0.0
      G=0.0
      DO 30 I=1,M
      C=C+(U(I)**2-VR(I)**2)
      D=D+2.0*U(I)*VR(I)
      S=S+U(I)
30   G=G+VR(I)
      TG1=D-2.0*S*G/(M*1.)
      TG2=C-(S**2-G**2)/(M*1.)
      FI=ATAN2(TG1,TG2)/4.0
C-----COMPUTE NEW A AND B WITH FI
      DO 75 I=1,M
      WT(I)=A(I,T)
75   WK(I)=A(I,K)
      DO 84 KK=1,N
      WBT(KK)=B(T,KK)
84   WBK(KK)=B(K,KK)
      DO 78 I=1,M
      A(I,T)=WT(I)*COS(FI)+WK(I)*SIN(FI)
78   A(I,K)=WT(I)*(-SIN(FI))+WK(I)*COS(FI)
      DO 89 IT=1,N
      B(T,IT)=WBT(IT)*COS(FI)+WBK(IT)*SIN(FI)
89   B(K,IT)=WBT(IT)*(-SIN(FI))+WBK(IT)*COS(FI)
C-----
      RETURN
      END
C-----*----------------------------------------------------6--------7--
C     SPECIFIED EIGNVECTORS AND TIME COEFFICIENTS WITH EXPLAINED VARIANCES
C       OF REOF (IF YOU NEED). IF NOT, THE LOADING VECTORS OF REOF  
C       CORRESPONDS TO THE EOF MODES.
C
C     INPUT: M,N,NP,REGVT,RECOF,TR
C       M: GRIDS
C       N: LENGTH OF TIME SERIES, VIZ. SAMPLE SIZE
C       NP: NUM. OF EIGENVECTORS TO ROTATE
C       REGVT(M,NP): THE ROTATED ARRAY OF EIGENVACTORS (LOADING VECTOR)
C       RECOF(NP,N): ARRAY OF TIME COEFFICIENTS FOR THE RESPECTIVE EIGENVECTORS
C       RER(MNL,1): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN)
C       RER(MNL,2): ACCUMULATED EXPLAINED VARIANCES
C
C     OUTPUT: REGVT,RECOF,RER
C       REGVT(M,NP): THE ROTATED ARRAY OF EIGENVACTORS (LOADING VECTOR)
C       RECOF(NP,N): ARRAY OF TIME COEFFICIENTS FOR THE RESPECTIVE EIGENVECTORS
C       RER(MNL,1): EXPLAINED VARIANCES (LAMDA/TOTAL EXPLAIN)
C       RER(MNL,2): ACCUMULATED EXPLAINED VARIANCES
C
C     BY DONG XIAO, AUG 21, 2006
C-----
      SUBROUTINE ARRANGE2(M,N,NP,REGVT,RECOF,RER)
!-----INPUT AND OUTPUT ARRAYS         
      DIMENSION REGVT(M,NP),RECOF(NP,N),RER(NP,2)


      MNL1=NP-1
      DO 20 K1=MNL1,1,-1
      DO 20 K2=K1,MNL1
        IF(RER(K2,1).LT.RER(K2+1,1)) THEN
          C=RER(K2+1,1)
          RER(K2+1,1)=RER(K2,1)
          RER(K2,1)=C
          DO I=1,M
            D=REGVT(I,K2+1)
            REGVT(I,K2+1)=REGVT(I,K2)
            REGVT(I,K2)=D
          END DO
          DO I=1,N
            E=RECOF(K2+1,I)
            RECOF(K2+1,I)=RECOF(K2,I)
            RECOF(K2,I)=E
          END DO
        ENDIF
  20  CONTINUE
      DO I=1,NP
RER(I,2)=0.0
END DO
      RER(1,2)=RER(1,1)
      DO 30 I=2,NP
        RER(I,2)=RER(I-1,2)+RER(I,1)
  30  CONTINUE
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     COMPUTING THE MEAN AX, STANDARD DEVIATION SX
C       AND VARIANCE VX OF A SERIES X(I) (I=1,...,N).
C
C     INPUT: N AND X(N)
C       N: LENGTH OF RAW SERIES
C       X(N): RAW SERIES
C
C     OUTPUT: AX, SX AND VX
C       AX: THE MEAN VALUE OF X(N)
C       SX: THE STANDARD DEVIATION OF X(N)
C       VX: THE VARIANCE OF X(N)
C
C     BY DR. JIANPING LI, MAY 6, 1999.
C-----
      SUBROUTINE MEANVAR(N,X,AX,SX,VX)
!-----INPUT ARRAY
      DIMENSION X(N)


      AX=0.
      VX=0.
      SX=0.
      DO 10 I=1,N
        AX=AX+X(I)
  10  CONTINUE
      AX=AX/FLOAT(N)
      DO 20 I=1,N
        VX=VX+(X(I)-AX)**2
  20  CONTINUE
      VX=VX/FLOAT(N)
      SX=SQRT(VX)
C-----
      RETURN
      END
C-----*----------------------------------------------------6---------7--
C     THIS SUBROUTINE IS FOR REMOVING ANNUAL CYCLE (MONTHLY OF DAILY DATA)
C     
C     INPUT:
C       ND: NUMBER OF DAYS OR MONTHES IN A YEAR.
C       NY: NUMBER OF YEAR
C       NDY=ND*NY
C       F(NDY): THE DAILY OF MONTHLY DATA.
C
C     OUTPUT:
C       AF(NDY): THE DAILY OF MONTHLY DATA WITHOUT ANNUAL CYCLE
C
C     BY DR JIANPING LI,  
C     RECOMPLIED BY DONG XIAO ON MAY 7, 2007
C-----
      SUBROUTINE INITIAL(ND,NY,NDY,F,AF)
!-----INPUT ARRAY
REAL F(NDY)
!-----WORK ARRAYS
REAL FAVE(ND),FSTD(ND)
!-----OUTPUT ARRAY
REAL AF(NDY)
C-----
DO I=1,ND
FAVE(I)=0.
DO J=1,NY
   FAVE(I)=FAVE(I)+F(I+(J-1)*ND)
ENDDO
FAVE(I)=FAVE(I)/NY
FSTD(I)=0.0
DO J=1,NY
   FSTD(I)=FSTD(I)+(F(I+(J-1)*ND)-FAVE(I))**2
ENDDO
FSTD(I)=SQRT(FSTD(I)/FLOAT(NY))
DO J=1,NY
   IJ=I+(J-1)*ND
C-----STANDARD DEPARTURE
C           AF(IJ)=(F(IJ)-FAVE(I))/FSTD(I)
C-----DEPARTURE
AF(IJ)=(F(IJ)-FAVE(I))
ENDDO
ENDDO
C-----
RETURN
END
C-----*----------------------------------------------------6---------7--

密码修改失败请联系微信:mofangbao

新浪微博达人勋

0
早起挑战累计收入
发表于 2013-12-16 19:43:15 | 显示全部楼层
建议楼主多跟师兄师姐讨论下是否真的是错误,或者联系李老师咨询看看,权威当然是可以挑战的,但是要有依据哦,楼主可以说明一下原来为什么不对,现在这样改的理由是什么,也许是我不太知道这个方法,熟悉的人能否一眼就看出错误呢
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2013-12-17 11:07:12 | 显示全部楼层

我之前在帖子上看到有人说这个程序有些错误,我验算过高度场和海温场,这个程序是对的,只是有两行Write(*,*)输出结果是李老师忘记了除以时间长度的平方,所以以前输出的各模态百分比有错误。这并非挑战。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2013-12-17 11:15:02 | 显示全部楼层
楼主很仔细,建议和李老师说一声,他很高兴和别人讨论问题的,这样他可以及时更新,方便后面的人使用。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2013-12-17 11:17:30 | 显示全部楼层
錯莂牸 发表于 2013-12-17 11:15
楼主很仔细,建议和李老师说一声,他很高兴和别人讨论问题的,这样他可以及时更新,方便后面的人使用。

您想的更加周到,我会写邮件告诉李老师。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-18 12:58:51 | 显示全部楼层
请问楼主,我用李建平老师的reof程序做出来的eof结果部分跟用他的eof程序做出来的结果为啥不一样?
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-18 15:41:31 | 显示全部楼层
看到这样的讨论帖总是让人开心~
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-12-19 22:05:27 | 显示全部楼层
慧子 发表于 2014-12-18 12:58
请问楼主,我用李建平老师的reof程序做出来的eof结果部分跟用他的eof程序做出来的结果为啥不一样?

不可能,也许你出错了
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表