* G03ECF Example Program Text * Mark 17 Revised. NAG Copyright 1995. * * .. Parameters .. INTEGER NIN, NOUT PARAMETER (NIN=5,NOUT=6) INTEGER NMAX, MMAX, LENC PARAMETER (NMAX=10,MMAX=10,LENC=20) * .. Local Scalars .. DOUBLE PRECISION DMIN, DSTEP, YDIST INTEGER I, IFAIL, J, LDX, M, METHOD, N, NSYM CHARACTER DIST, SCALE, UPDATE * .. Local Arrays .. DOUBLE PRECISION CD(NMAX-1), D(NMAX*(NMAX-1)/2), DORD(NMAX), + S(MMAX), X(NMAX,MMAX) INTEGER ILC(NMAX-1), IORD(NMAX), ISX(MMAX), IUC(NMAX-1), + IWK(2*NMAX) CHARACTER*3 NAME(NMAX) CHARACTER*60 C(LENC) * .. External Subroutines .. EXTERNAL G03EAF, G03ECF, G03EHF * .. Intrinsic Functions .. INTRINSIC DBLE, MOD * .. Executable Statements .. WRITE (NOUT,*) 'G03ECF Example Program Results' * Skip heading in data file READ (NIN,*) READ (NIN,*) N, M IF (N.LE.NMAX .AND. M.LE.MMAX) THEN READ (NIN,*) METHOD READ (NIN,*) UPDATE, DIST, SCALE DO 20 J = 1, N READ (NIN,*) (X(J,I),I=1,M), NAME(J) 20 CONTINUE READ (NIN,*) (ISX(I),I=1,M) READ (NIN,*) (S(I),I=1,M) * * Compute the distance matrix * IFAIL = 0 LDX = NMAX * CALL G03EAF(UPDATE,DIST,SCALE,N,M,X,LDX,ISX,S,D,IFAIL) * * Perform clustering * IFAIL = 0 * CALL G03ECF(METHOD,N,D,ILC,IUC,CD,IORD,DORD,IWK,IFAIL) * WRITE (NOUT,*) WRITE (NOUT,*) ' Distance Clusters Joined' WRITE (NOUT,*) DO 40 I = 1, N - 1 WRITE (NOUT,99999) CD(I), NAME(ILC(I)), NAME(IUC(I)) 40 CONTINUE * * Produce dendrogram * IFAIL = 0 NSYM = LENC DMIN = 0.0D0 DSTEP = (CD(N-1))/DBLE(NSYM) * CALL G03EHF('S',N,DORD,DMIN,DSTEP,NSYM,C,LENC,IFAIL) * WRITE (NOUT,*) WRITE (NOUT,*) 'Dendrogram' WRITE (NOUT,*) YDIST = CD(N-1) DO 60 I = 1, NSYM IF (MOD(I,3).EQ.1) THEN WRITE (NOUT,99999) YDIST, C(I) ELSE WRITE (NOUT,99998) C(I) END IF YDIST = YDIST - DSTEP 60 CONTINUE WRITE (NOUT,*) WRITE (NOUT,99998) (NAME(IORD(I)),I=1,N) END IF STOP * 99999 FORMAT (F10.3,5X,2A) 99998 FORMAT (15X,20A) END