1 | SUBROUTINE dump2ds(im,jm,z,nom_z) |
---|
2 | C Copyright (C) 2005 Centre National de la Recherche Scientifique |
---|
3 | c ================================================================== |
---|
4 | c Perform a scatter plot print of big matrices using regular |
---|
5 | c intervals between min and max matrix coefficient values. |
---|
6 | c ================================================================== |
---|
7 | c adapted from LMD3 by Alain Lahellec and retranscipted for LMDZ5 |
---|
8 | c NAN et INF ajoute aux plots Pat fin 2006 |
---|
9 | c ================================================================== |
---|
10 | c Comme dump2d sauf que le signe est préservé, la valeur zero |
---|
11 | c identifiee par un blanc. |
---|
12 | c detection des Infty (= ou -) et NaN (?) |
---|
13 | c ================================================================== |
---|
14 | IMPLICIT NONE |
---|
15 | INTEGER im,jm |
---|
16 | REAL z(im,jm),az |
---|
17 | CHARACTER*32 jform,jline*1000 |
---|
18 | CHARACTER*1 iform(32) |
---|
19 | CHARACTER*16 F1000 |
---|
20 | logical zinf,znan,zsign |
---|
21 | CHARACTER (len=*) :: nom_z |
---|
22 | INTEGER*4 icheck(2) |
---|
23 | EQUIVALENCE(az,icheck) |
---|
24 | EQUIVALENCE(iform,jform) |
---|
25 | DATA jform/'-@zyxwvutsrqpon NOPQRSTUVWXYZ*+?'/ |
---|
26 | INTEGER i,j,k,imin,imax,jmin,jmax,kzero,kchar(im) |
---|
27 | REAL zmin,zmax,zllu,zllm |
---|
28 | write(F1000,'(''(4x,'',I3,''(1H-))'')')im+3 |
---|
29 | DO 10001 i=1,200 |
---|
30 | jline(1+(i-1)*5:5*i)='. ' |
---|
31 | 10001 CONTINUE |
---|
32 | 10002 zmin=z(1,1) |
---|
33 | imin=1 |
---|
34 | jmin=1 |
---|
35 | zmax=z(1,1) |
---|
36 | imax=1 |
---|
37 | jmax=1 |
---|
38 | kzero=0 |
---|
39 | DO 10003 j=1,jm |
---|
40 | DO 10005 i=1,im |
---|
41 | IF(.NOT.( z(i,j).GT.zmax))GOTO 10007 |
---|
42 | zmax=z(i,j) |
---|
43 | imax=i |
---|
44 | jmax=j |
---|
45 | 10007 IF(.NOT.( z(i,j).LT.zmin))GOTO 10009 |
---|
46 | zmin=z(i,j) |
---|
47 | imin=i |
---|
48 | jmin=j |
---|
49 | 10009 IF(.NOT.( z(i,j).eq.0.))GOTO 10011 |
---|
50 | kzero=kzero+1 |
---|
51 | 10011 CONTINUE |
---|
52 | 10005 CONTINUE |
---|
53 | 10006 CONTINUE |
---|
54 | 10003 CONTINUE |
---|
55 | 10004 zsign=(sign(1.,zmin)*sign(1.,zmax).gt.0.) |
---|
56 | WRITE(*,*)'>>> dump2ds: ',trim(nom_z) |
---|
57 | PRINT*,'>>> ',kzero,' zero values <<<' |
---|
58 | IF(.NOT.( ZMin.lt.0.))GOTO 10013 |
---|
59 | PRINT2000,' [MIN:',zmin,'(',imin,',',jmin,') (-@zyxwvutsrqpon NOPQ |
---|
60 | *RSTUVWXYZ*+) ',zmax,'(',imax,',',jmax,'):MAX]' |
---|
61 | GOTO 10014 |
---|
62 | 10013 PRINT2000,' [MIN:',zmin,'(',imin,',',jmin,') ( NOPQRSTUVWXYZ*+) ', |
---|
63 | *zmax,'(',imax,',',jmax,'):MAX]' |
---|
64 | 10014 CONTINUE |
---|
65 | 2000 Format(a,1pg11.4,a1,i3,a1,i3,a,1pg11.4,a1,i3,a1,i3,a) |
---|
66 | IF(.NOT.( zmax.GT.zmin))GOTO 10015 |
---|
67 | zllm=max(abs(zmax),abs(zmin)) |
---|
68 | zllu=min(abs(zmax),abs(zmin)) |
---|
69 | if(im.ge.100)WRITE(*,'(104x,900i1)')(mod(i/100,10),i=100,im) |
---|
70 | WRITE(*,'(14x,1000i1)')(mod(i/10,10),i=10,im) |
---|
71 | WRITE(*,'(5x,1009i1)')(mod(i,10),i=1,im) |
---|
72 | write(*,F1000) |
---|
73 | zinf=.false. |
---|
74 | znan=.false. |
---|
75 | DO 10017 j=1,jm |
---|
76 | DO 10019 i=1,im |
---|
77 | az=abs(z(i,j)) |
---|
78 | IF(.NOT.( az.eq.0.))GOTO 10021 |
---|
79 | kchar(i)=16 |
---|
80 | GOTO 10022 |
---|
81 | 10021 IF(.NOT.((az.ne.0.and.icheck(1).eq.0.and.icheck(2).eq.2146435072)) |
---|
82 | *)GOTO 10023 |
---|
83 | kchar(i)=31 |
---|
84 | zinf=.true. |
---|
85 | GOTO 10022 |
---|
86 | 10023 IF(.NOT.((az.ne.0.and.icheck(1).eq.0.and.icheck(2).eq.2146959360)) |
---|
87 | *)GOTO 10024 |
---|
88 | kchar(i)=32 |
---|
89 | znan=.true. |
---|
90 | GOTO 10022 |
---|
91 | 10024 IF(.NOT.( zsign))GOTO 10025 |
---|
92 | kchar(i)=NINT(13.*(az-zllu)/(zllm-zllu)+17) |
---|
93 | GOTO 10026 |
---|
94 | 10025 kchar(i)=NINT(13.*az/zllm+17) |
---|
95 | 10026 CONTINUE |
---|
96 | 10022 IF(.NOT.( z(i,j).lt.0.))GOTO 10027 |
---|
97 | kchar(i)=32-kchar(i) |
---|
98 | 10027 CONTINUE |
---|
99 | 10019 CONTINUE |
---|
100 | 10020 WRITE(*,'(1x,i3,''|'',1000a)')j+1,(iform(kchar(i)),i=1,im),'|','| |
---|
101 | *' |
---|
102 | 10017 CONTINUE |
---|
103 | 10018 write(*,F1000) |
---|
104 | WRITE(*,'(5x,1000i1)')(mod(i,10),i=1,im) |
---|
105 | WRITE(*,'(14x,1000i1)')(mod(i/10,10),i=10,im) |
---|
106 | if(im.ge.100)WRITE(*,'(104x,900i1)')(mod(i/100,10),i=100,im) |
---|
107 | GOTO 10016 |
---|
108 | 10015 print*,'>>> ZERO MAP <<<' |
---|
109 | 10016 if(zinf)print*,' *** Infty value(s) (+ or -) in map ***' |
---|
110 | if(znan)print*,' *** NaN value(s) (?) in map ***' |
---|
111 | print* |
---|
112 | RETURN |
---|
113 | END |
---|