source: trunk/src/mode_sahelien/composite_wind200_rossby.m @ 23

Last change on this file since 23 was 23, checked in by pinsard, 15 years ago

replace fcommands save, load and print by function calls

File size: 20.7 KB
Line 
1%
2
3% initialisation
4clear;
5close all;
6
7% etape 1 :on selectionne les mois d ete (attention aux annees bixestiles!)
8%          on compile sous forme d'un seul fichier
9
10uwnd200=zeros(122,49,144,22);
11
12siz=31+28+31+30+31+1;
13sizbis=31+28+31+30+31+30+31+31+30;
14ncload('uwnd200.1979.nc'); uwnd200(:,:,:,1)=uwnd(siz:sizbis,1,:,:); clear uwnd;
15ncload('uwnd200.1980.nc'); uwnd200(:,:,:,2)=uwnd(siz+1:sizbis+1,1,:,:); clear uwnd;
16ncload('uwnd200.1981.nc'); uwnd200(:,:,:,3)=uwnd(siz:sizbis,1,:,:);clear uwnd;
17ncload('uwnd200.1982.nc'); uwnd200(:,:,:,4)=uwnd(siz:sizbis,1,:,:);clear uwnd;
18ncload('uwnd200.1983.nc'); uwnd200(:,:,:,5)=uwnd(siz:sizbis,1,:,:);clear uwnd;
19ncload('uwnd200.1984.nc'); uwnd200(:,:,:,6)=uwnd(siz+1:sizbis+1,1,:,:);clear uwnd;
20ncload('uwnd200.1985.nc'); uwnd200(:,:,:,7)=uwnd(siz:sizbis,1,:,:);clear uwnd;
21ncload('uwnd200.1986.nc'); uwnd200(:,:,:,8)=uwnd(siz:sizbis,1,:,:);clear uwnd;
22ncload('uwnd200.1987.nc'); uwnd200(:,:,:,9)=uwnd(siz:sizbis,1,:,:);clear uwnd;
23ncload('uwnd200.1988.nc'); uwnd200(:,:,:,10)=uwnd(siz+1:sizbis+1,1,:,:);clear uwnd;
24ncload('uwnd200.1989.nc'); uwnd200(:,:,:,11)=uwnd(siz:sizbis,1,:,:);clear uwnd;
25ncload('uwnd200.1990.nc'); uwnd200(:,:,:,12)=uwnd(siz:sizbis,1,:,:);clear uwnd;
26ncload('uwnd200.1991.nc'); uwnd200(:,:,:,13)=uwnd(siz:sizbis,1,:,:);clear uwnd;
27ncload('uwnd200.1992.nc'); uwnd200(:,:,:,14)=uwnd(siz+1:sizbis+1,1,:,:);clear uwnd;
28ncload('uwnd200.1993.nc'); uwnd200(:,:,:,15)=uwnd(siz:sizbis,1,:,:);clear uwnd;
29ncload('uwnd200.1994.nc'); uwnd200(:,:,:,16)=uwnd(siz:sizbis,1,:,:);clear uwnd;
30ncload('uwnd200.1995.nc'); uwnd200(:,:,:,17)=uwnd(siz:sizbis,1,:,:);clear uwnd;
31ncload('uwnd200.1996.nc'); uwnd200(:,:,:,18)=uwnd(siz+1:sizbis+1,1,:,:);clear uwnd;
32ncload('uwnd200.1997.nc'); uwnd200(:,:,:,19)=uwnd(siz:sizbis,1,:,:);clear uwnd;
33ncload('uwnd200.1998.nc'); uwnd200(:,:,:,20)=uwnd(siz:sizbis,1,:,:);clear uwnd;
34ncload('uwnd200.1999.nc'); uwnd200(:,:,:,21)=uwnd(siz:sizbis,1,:,:);clear uwnd;
35ncload('uwnd200.2000.nc'); uwnd200(:,:,:,22)=uwnd(siz+1:sizbis+1,1,:,:);clear uwnd;
36clear siz1 siz1bis;
37
38uwnd=permute(uwnd200,[1 4 2 3]);
39clear uwnd200;
40
41status=load('eof2_olr_rossby_jjas.txt');
42% on met sous la forme annee mois
43olr_eof=reshape(eof2_olr_rossby_jjas,122,22);
44clear eof2_olr_rossby_jjas;
45
46% on calcule l ecart type sur la serie temporelle de l'olr
47k=122*22;
48olrbis=reshape(olr_eof,k,1);
49olrbis=std(olrbis);
50
51% intialisation des tableaux
52uwnd200_filtre_compomax=NaN*ones(60,31,49,144);
53uwnd200_filtre_compomin=NaN*ones(60,31,49,144);
54
55compteurmax=0;
56compteurmin=0;
57
58% boucle sur les annees
59for a=1:22;
60   clear delta;
61   delta=zeros(122,1);
62   % boucle sur les jours : on prepare avant
63   for b=1:122;
64        if b>1;
65            delta(b)=olr_eof(b,a)-olr_eof(b-1,a);
66        end;
67   end;
68   % boucle sur les jours
69   for b=1:122;
70      % 1ere condition (laisser une marge de 10)
71      if (b>20 && b<112);
72% cas 1 : max deltas apres negetifs et deltas avant postifs
73         if (delta(b+1)<0 && delta(b)<0 && delta(b-1)>0 && delta(b-2)>0 && olr_eof(b,a)>olrbis);
74            compteurmax=compteurmax+1;
75            uwnd200_filtre_compomax(compteurmax,1,:,:)=uwnd(b-20,a,:,:);
76            uwnd200_filtre_compomax(compteurmax,2,:,:)=uwnd(b-19,a,:,:);
77            uwnd200_filtre_compomax(compteurmax,3,:,:)=uwnd(b-18,a,:,:);
78            uwnd200_filtre_compomax(compteurmax,4,:,:)=uwnd(b-17,a,:,:);
79            uwnd200_filtre_compomax(compteurmax,5,:,:)=uwnd(b-16,a,:,:);
80            uwnd200_filtre_compomax(compteurmax,6,:,:)=uwnd(b-15,a,:,:);
81            uwnd200_filtre_compomax(compteurmax,7,:,:)=uwnd(b-14,a,:,:);
82            uwnd200_filtre_compomax(compteurmax,8,:,:)=uwnd(b-13,a,:,:);
83            uwnd200_filtre_compomax(compteurmax,9,:,:)=uwnd(b-12,a,:,:);
84            uwnd200_filtre_compomax(compteurmax,10,:,:)=uwnd(b-11,a,:,:);
85
86            uwnd200_filtre_compomax(compteurmax,11,:,:)=uwnd(b-10,a,:,:);
87            uwnd200_filtre_compomax(compteurmax,12,:,:)=uwnd(b-9,a,:,:);
88            uwnd200_filtre_compomax(compteurmax,13,:,:)=uwnd(b-8,a,:,:);
89            uwnd200_filtre_compomax(compteurmax,14,:,:)=uwnd(b-7,a,:,:);
90            uwnd200_filtre_compomax(compteurmax,15,:,:)=uwnd(b-6,a,:,:);
91            uwnd200_filtre_compomax(compteurmax,16,:,:)=uwnd(b-5,a,:,:);
92            uwnd200_filtre_compomax(compteurmax,17,:,:)=uwnd(b-4,a,:,:);
93            uwnd200_filtre_compomax(compteurmax,18,:,:)=uwnd(b-3,a,:,:);
94            uwnd200_filtre_compomax(compteurmax,19,:,:)=uwnd(b-2,a,:,:);
95            uwnd200_filtre_compomax(compteurmax,20,:,:)=uwnd(b-1,a,:,:);
96
97            uwnd200_filtre_compomax(compteurmax,21,:,:)=uwnd(b,a,:,:);
98            uwnd200_filtre_compomax(compteurmax,22,:,:)=uwnd(b+1,a,:,:);
99            uwnd200_filtre_compomax(compteurmax,23,:,:)=uwnd(b+2,a,:,:);
100            uwnd200_filtre_compomax(compteurmax,24,:,:)=uwnd(b+3,a,:,:);
101            uwnd200_filtre_compomax(compteurmax,25,:,:)=uwnd(b+4,a,:,:);
102            uwnd200_filtre_compomax(compteurmax,26,:,:)=uwnd(b+5,a,:,:);
103            uwnd200_filtre_compomax(compteurmax,27,:,:)=uwnd(b+6,a,:,:);
104            uwnd200_filtre_compomax(compteurmax,28,:,:)=uwnd(b+7,a,:,:);
105            uwnd200_filtre_compomax(compteurmax,29,:,:)=uwnd(b+8,a,:,:);
106            uwnd200_filtre_compomax(compteurmax,30,:,:)=uwnd(b+9,a,:,:);
107            uwnd200_filtre_compomax(compteurmax,31,:,:)=uwnd(b+10,a,:,:);
108% cas 2 : min deltas apres positifs et deltas avant negatifs
109         elseif (delta(b+1)>0 && delta(b)>0 && delta(b-1)<0 && delta(b-2)<0 && olr_eof(b,a)<(-olrbis));
110            compteurmin=compteurmin+1;
111
112            uwnd200_filtre_compomin(compteurmin,1,:,:)=uwnd(b-20,a,:,:);
113            uwnd200_filtre_compomin(compteurmin,2,:,:)=uwnd(b-19,a,:,:);
114            uwnd200_filtre_compomin(compteurmin,3,:,:)=uwnd(b-18,a,:,:);
115            uwnd200_filtre_compomin(compteurmin,4,:,:)=uwnd(b-17,a,:,:);
116            uwnd200_filtre_compomin(compteurmin,5,:,:)=uwnd(b-16,a,:,:);
117            uwnd200_filtre_compomin(compteurmin,6,:,:)=uwnd(b-15,a,:,:);
118            uwnd200_filtre_compomin(compteurmin,7,:,:)=uwnd(b-14,a,:,:);
119            uwnd200_filtre_compomin(compteurmin,8,:,:)=uwnd(b-13,a,:,:);
120            uwnd200_filtre_compomin(compteurmin,9,:,:)=uwnd(b-12,a,:,:);
121            uwnd200_filtre_compomin(compteurmin,10,:,:)=uwnd(b-11,a,:,:);
122
123            uwnd200_filtre_compomin(compteurmin,11,:,:)=uwnd(b-10,a,:,:);
124            uwnd200_filtre_compomin(compteurmin,12,:,:)=uwnd(b-9,a,:,:);
125            uwnd200_filtre_compomin(compteurmin,13,:,:)=uwnd(b-8,a,:,:);
126            uwnd200_filtre_compomin(compteurmin,14,:,:)=uwnd(b-7,a,:,:);
127            uwnd200_filtre_compomin(compteurmin,15,:,:)=uwnd(b-6,a,:,:);
128            uwnd200_filtre_compomin(compteurmin,16,:,:)=uwnd(b-5,a,:,:);
129            uwnd200_filtre_compomin(compteurmin,17,:,:)=uwnd(b-4,a,:,:);
130            uwnd200_filtre_compomin(compteurmin,18,:,:)=uwnd(b-3,a,:,:);
131            uwnd200_filtre_compomin(compteurmin,19,:,:)=uwnd(b-2,a,:,:);
132            uwnd200_filtre_compomin(compteurmin,20,:,:)=uwnd(b-1,a,:,:);
133
134            uwnd200_filtre_compomin(compteurmin,21,:,:)=uwnd(b,a,:,:);
135            uwnd200_filtre_compomin(compteurmin,22,:,:)=uwnd(b+1,a,:,:);
136            uwnd200_filtre_compomin(compteurmin,23,:,:)=uwnd(b+2,a,:,:);
137            uwnd200_filtre_compomin(compteurmin,24,:,:)=uwnd(b+3,a,:,:);
138            uwnd200_filtre_compomin(compteurmin,25,:,:)=uwnd(b+4,a,:,:);
139            uwnd200_filtre_compomin(compteurmin,26,:,:)=uwnd(b+5,a,:,:);
140            uwnd200_filtre_compomin(compteurmin,27,:,:)=uwnd(b+6,a,:,:);
141            uwnd200_filtre_compomin(compteurmin,28,:,:)=uwnd(b+7,a,:,:);
142            uwnd200_filtre_compomin(compteurmin,29,:,:)=uwnd(b+8,a,:,:);
143            uwnd200_filtre_compomin(compteurmin,30,:,:)=uwnd(b+9,a,:,:);
144            uwnd200_filtre_compomin(compteurmin,31,:,:)=uwnd(b+10,a,:,:);
145         end;
146      end;
147   end;
148end;
149
150% on fait la somme des valeurs de uwnd200_filtreentiel sur le nbre d occurences
151% on obtent un tableau de la forme (jours-avant-apres,lon,lat)
152uwnd200_filtre_compomin1(:,:,:)=nanmean(uwnd200_filtre_compomin);
153clear uwnd200_filtre_compomin;
154uwnd200_filtre_compomax1(:,:,:)=nanmean(uwnd200_filtre_compomax);
155clear uwnd200_filtre_compomax;
156
157% etape 1 :on selectionne les mois d ete (attention aux annees bixestiles!)
158%          on compile sous forme d'un seul fichier
159
160vwnd200=zeros(122,49,144,22);
161
162siz=31+28+31+30+31+1;
163sizbis=31+28+31+30+31+30+31+31+30;
164ncload('vwnd200.1979.nc'); vwnd200(:,:,:,1)=vwnd(siz:sizbis,1,:,:); clear vwnd;
165ncload('vwnd200.1980.nc'); vwnd200(:,:,:,2)=vwnd(siz+1:sizbis+1,1,:,:); clear vwnd;
166ncload('vwnd200.1981.nc'); vwnd200(:,:,:,3)=vwnd(siz:sizbis,1,:,:);clear vwnd;
167ncload('vwnd200.1982.nc'); vwnd200(:,:,:,4)=vwnd(siz:sizbis,1,:,:);clear vwnd;
168ncload('vwnd200.1983.nc'); vwnd200(:,:,:,5)=vwnd(siz:sizbis,1,:,:);clear vwnd;
169ncload('vwnd200.1984.nc'); vwnd200(:,:,:,6)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
170ncload('vwnd200.1985.nc'); vwnd200(:,:,:,7)=vwnd(siz:sizbis,1,:,:);clear vwnd;
171ncload('vwnd200.1986.nc'); vwnd200(:,:,:,8)=vwnd(siz:sizbis,1,:,:);clear vwnd;
172ncload('vwnd200.1987.nc'); vwnd200(:,:,:,9)=vwnd(siz:sizbis,1,:,:);clear vwnd;
173ncload('vwnd200.1988.nc'); vwnd200(:,:,:,10)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
174ncload('vwnd200.1989.nc'); vwnd200(:,:,:,11)=vwnd(siz:sizbis,1,:,:);clear vwnd;
175ncload('vwnd200.1990.nc'); vwnd200(:,:,:,12)=vwnd(siz:sizbis,1,:,:);clear vwnd;
176ncload('vwnd200.1991.nc'); vwnd200(:,:,:,13)=vwnd(siz:sizbis,1,:,:);clear vwnd;
177ncload('vwnd200.1992.nc'); vwnd200(:,:,:,14)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
178ncload('vwnd200.1993.nc'); vwnd200(:,:,:,15)=vwnd(siz:sizbis,1,:,:);clear vwnd;
179ncload('vwnd200.1994.nc'); vwnd200(:,:,:,16)=vwnd(siz:sizbis,1,:,:);clear vwnd;
180ncload('vwnd200.1995.nc'); vwnd200(:,:,:,17)=vwnd(siz:sizbis,1,:,:);clear vwnd;
181ncload('vwnd200.1996.nc'); vwnd200(:,:,:,18)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
182ncload('vwnd200.1997.nc'); vwnd200(:,:,:,19)=vwnd(siz:sizbis,1,:,:);clear vwnd;
183ncload('vwnd200.1998.nc'); vwnd200(:,:,:,20)=vwnd(siz:sizbis,1,:,:);clear vwnd;
184ncload('vwnd200.1999.nc'); vwnd200(:,:,:,21)=vwnd(siz:sizbis,1,:,:);clear vwnd;
185ncload('vwnd200.2000.nc'); vwnd200(:,:,:,22)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
186clear siz1 siz1bis;
187
188vwnd=permute(vwnd200,[1 4 2 3]);
189clear vwnd200;
190
191status=load('eof2_olr_rossby_jjas.txt');
192% on met sous la forme annee mois
193olr_eof=reshape(eof2_olr_rossby_jjas,122,22);
194clear eof2_olr_rossby_jjas;
195
196% on calcule l ecart type sur la serie temporelle de l'olr
197k=122*22;
198olrbis=reshape(olr_eof,k,1);
199olrbis=std(olrbis);
200
201% intialisation des tableaux
202vwnd200_filtre_compomax=NaN*ones(60,31,49,144);
203vwnd200_filtre_compomin=NaN*ones(60,31,49,144);
204
205compteurmax=0;
206compteurmin=0;
207
208% boucle sur les annees
209for a=1:22;
210   clear delta;
211   delta=zeros(122,1);
212   % boucle sur les jours : on prepare avant
213   for b=1:122;
214        if b>1;
215            delta(b)=olr_eof(b,a)-olr_eof(b-1,a);
216        end;
217   end;
218   % boucle sur les jours
219   for b=1:122;
220      % 1ere condition (laisser une marge de 10)
221      if (b>20 && b<112);
222% cas 1 : max deltas apres negetifs et deltas avant postifs
223         if (delta(b+1)<0 && delta(b)<0 && delta(b-1)>0 && delta(b-2)>0 && olr_eof(b,a)>olrbis);
224            compteurmax=compteurmax+1;
225            vwnd200_filtre_compomax(compteurmax,1,:,:)=vwnd(b-20,a,:,:);
226            vwnd200_filtre_compomax(compteurmax,2,:,:)=vwnd(b-19,a,:,:);
227            vwnd200_filtre_compomax(compteurmax,3,:,:)=vwnd(b-18,a,:,:);
228            vwnd200_filtre_compomax(compteurmax,4,:,:)=vwnd(b-17,a,:,:);
229            vwnd200_filtre_compomax(compteurmax,5,:,:)=vwnd(b-16,a,:,:);
230            vwnd200_filtre_compomax(compteurmax,6,:,:)=vwnd(b-15,a,:,:);
231            vwnd200_filtre_compomax(compteurmax,7,:,:)=vwnd(b-14,a,:,:);
232            vwnd200_filtre_compomax(compteurmax,8,:,:)=vwnd(b-13,a,:,:);
233            vwnd200_filtre_compomax(compteurmax,9,:,:)=vwnd(b-12,a,:,:);
234            vwnd200_filtre_compomax(compteurmax,10,:,:)=vwnd(b-11,a,:,:);
235
236            vwnd200_filtre_compomax(compteurmax,11,:,:)=vwnd(b-10,a,:,:);
237            vwnd200_filtre_compomax(compteurmax,12,:,:)=vwnd(b-9,a,:,:);
238            vwnd200_filtre_compomax(compteurmax,13,:,:)=vwnd(b-8,a,:,:);
239            vwnd200_filtre_compomax(compteurmax,14,:,:)=vwnd(b-7,a,:,:);
240            vwnd200_filtre_compomax(compteurmax,15,:,:)=vwnd(b-6,a,:,:);
241            vwnd200_filtre_compomax(compteurmax,16,:,:)=vwnd(b-5,a,:,:);
242            vwnd200_filtre_compomax(compteurmax,17,:,:)=vwnd(b-4,a,:,:);
243            vwnd200_filtre_compomax(compteurmax,18,:,:)=vwnd(b-3,a,:,:);
244            vwnd200_filtre_compomax(compteurmax,19,:,:)=vwnd(b-2,a,:,:);
245            vwnd200_filtre_compomax(compteurmax,20,:,:)=vwnd(b-1,a,:,:);
246
247            vwnd200_filtre_compomax(compteurmax,21,:,:)=vwnd(b,a,:,:);
248            vwnd200_filtre_compomax(compteurmax,22,:,:)=vwnd(b+1,a,:,:);
249            vwnd200_filtre_compomax(compteurmax,23,:,:)=vwnd(b+2,a,:,:);
250            vwnd200_filtre_compomax(compteurmax,24,:,:)=vwnd(b+3,a,:,:);
251            vwnd200_filtre_compomax(compteurmax,25,:,:)=vwnd(b+4,a,:,:);
252            vwnd200_filtre_compomax(compteurmax,26,:,:)=vwnd(b+5,a,:,:);
253            vwnd200_filtre_compomax(compteurmax,27,:,:)=vwnd(b+6,a,:,:);
254            vwnd200_filtre_compomax(compteurmax,28,:,:)=vwnd(b+7,a,:,:);
255            vwnd200_filtre_compomax(compteurmax,29,:,:)=vwnd(b+8,a,:,:);
256            vwnd200_filtre_compomax(compteurmax,30,:,:)=vwnd(b+9,a,:,:);
257            vwnd200_filtre_compomax(compteurmax,31,:,:)=vwnd(b+10,a,:,:);
258% cas 2 : min deltas apres positifs et deltas avant negatifs
259         elseif (delta(b+1)>0 && delta(b)>0 && delta(b-1)<0 && delta(b-2)<0 && olr_eof(b,a)<(-olrbis));
260            compteurmin=compteurmin+1;
261
262            vwnd200_filtre_compomin(compteurmin,1,:,:)=vwnd(b-20,a,:,:);
263            vwnd200_filtre_compomin(compteurmin,2,:,:)=vwnd(b-19,a,:,:);
264            vwnd200_filtre_compomin(compteurmin,3,:,:)=vwnd(b-18,a,:,:);
265            vwnd200_filtre_compomin(compteurmin,4,:,:)=vwnd(b-17,a,:,:);
266            vwnd200_filtre_compomin(compteurmin,5,:,:)=vwnd(b-16,a,:,:);
267            vwnd200_filtre_compomin(compteurmin,6,:,:)=vwnd(b-15,a,:,:);
268            vwnd200_filtre_compomin(compteurmin,7,:,:)=vwnd(b-14,a,:,:);
269            vwnd200_filtre_compomin(compteurmin,8,:,:)=vwnd(b-13,a,:,:);
270            vwnd200_filtre_compomin(compteurmin,9,:,:)=vwnd(b-12,a,:,:);
271            vwnd200_filtre_compomin(compteurmin,10,:,:)=vwnd(b-11,a,:,:);
272
273            vwnd200_filtre_compomin(compteurmin,11,:,:)=vwnd(b-10,a,:,:);
274            vwnd200_filtre_compomin(compteurmin,12,:,:)=vwnd(b-9,a,:,:);
275            vwnd200_filtre_compomin(compteurmin,13,:,:)=vwnd(b-8,a,:,:);
276            vwnd200_filtre_compomin(compteurmin,14,:,:)=vwnd(b-7,a,:,:);
277            vwnd200_filtre_compomin(compteurmin,15,:,:)=vwnd(b-6,a,:,:);
278            vwnd200_filtre_compomin(compteurmin,16,:,:)=vwnd(b-5,a,:,:);
279            vwnd200_filtre_compomin(compteurmin,17,:,:)=vwnd(b-4,a,:,:);
280            vwnd200_filtre_compomin(compteurmin,18,:,:)=vwnd(b-3,a,:,:);
281            vwnd200_filtre_compomin(compteurmin,19,:,:)=vwnd(b-2,a,:,:);
282            vwnd200_filtre_compomin(compteurmin,20,:,:)=vwnd(b-1,a,:,:);
283
284            vwnd200_filtre_compomin(compteurmin,21,:,:)=vwnd(b,a,:,:);
285            vwnd200_filtre_compomin(compteurmin,22,:,:)=vwnd(b+1,a,:,:);
286            vwnd200_filtre_compomin(compteurmin,23,:,:)=vwnd(b+2,a,:,:);
287            vwnd200_filtre_compomin(compteurmin,24,:,:)=vwnd(b+3,a,:,:);
288            vwnd200_filtre_compomin(compteurmin,25,:,:)=vwnd(b+4,a,:,:);
289            vwnd200_filtre_compomin(compteurmin,26,:,:)=vwnd(b+5,a,:,:);
290            vwnd200_filtre_compomin(compteurmin,27,:,:)=vwnd(b+6,a,:,:);
291            vwnd200_filtre_compomin(compteurmin,28,:,:)=vwnd(b+7,a,:,:);
292            vwnd200_filtre_compomin(compteurmin,29,:,:)=vwnd(b+8,a,:,:);
293            vwnd200_filtre_compomin(compteurmin,30,:,:)=vwnd(b+9,a,:,:);
294            vwnd200_filtre_compomin(compteurmin,31,:,:)=vwnd(b+10,a,:,:);
295         end;
296      end;
297   end;
298end;
299
300% on fait la somme des valeurs de vwnd200_filtreentiel sur le nbre d occurences
301% on obtent un tableau de la forme (jours-avant-apres,lon,lat)
302vwnd200_filtre_compomin1(:,:,:)=nanmean(vwnd200_filtre_compomin);
303clear vwnd200_filtre_compomin;
304vwnd200_filtre_compomax1(:,:,:)=nanmean(vwnd200_filtre_compomax);
305clear vwnd200_filtre_compomax;
306
307figure(1)
308orient('landscape')
309status=load('pression.mat');
310
311for e=1:7;
312       a=7-(e-1)+1;
313       f=2*(a-1)+1;
314
315       clear delta_uwnd200_filtre_min;
316       clear delta_vwnd200_filtre_min;
317       delta_uwnd200_filtre_min=zeros(49,144);
318       delta_vwnd200_filtre_min=zeros(49,144);
319       for b=1:49;
320          for c=1:144;
321             delta_uwnd200_filtre_min(b,c)=uwnd200_filtre_compomin1(f,b,c)-uwnd200_filtre_compomax1(f,b,c);
322             delta_vwnd200_filtre_min(b,c)=vwnd200_filtre_compomin1(f,b,c)-vwnd200_filtre_compomax1(f,b,c);
323
324         end;
325       end;
326       subplot(7,1,8-e);
327
328       delta_vwnd200_filtre=zeros(49,144);
329       delta_uwnd200_filtre=zeros(49,144);
330       delta_vwnd200_filtre(:,1:72)=delta_vwnd200_filtre_min(:,73:144);
331       delta_vwnd200_filtre(:,73:144)=delta_vwnd200_filtre_min(:,1:72);
332       delta_uwnd200_filtre(:,1:72)=delta_uwnd200_filtre_min(:,73:144);
333       delta_uwnd200_filtre(:,73:144)=delta_uwnd200_filtre_min(:,1:72);
334       xi=[-180:3.75:176.25];
335       xi=xi';
336       yi=[-87.1591:3.708895:87.1591];
337       clear carteu cartev;
338       carteu=interp2(lon-180,lat,delta_uwnd200_filtre,xi,yi);
339       cartev=interp2(lon-180,lat,delta_vwnd200_filtre,xi,yi);
340       clear coco ;
341       coco(:,:)=pression(a,:,:);
342      hgt=interp2(lon-180,lat,coco,xi,yi);
343       palette
344       aa=contourf(xi,yi,hgt,[-50:5:50],'LineStyle','none');
345       hold on;
346       aa=quiver(xi,yi,carteu,cartev,'k');
347       if e==1;
348       set (gca,'XTick',[-180:60:180],'XTickLabel',[' 180';'120W';' 60W';'   0';' 60E';'120E';' 180'],'fontname','Arial','fontsize',6);
349       else
350      set (gca,'XTick',[-180:60:180],'XTickLabel',[' ';' ';' ';' ';' ';' '],'fontname','Arial','fontsize',6);
351       end
352       set (gca,'YTick',[-10:10:40],'YTickLabel',['   ';'  0';'10N';'20N';'30N';'   '],'fontname','Arial','fontsize',6);
353       cartemonde1;
354       if e==4;
355          co=colorbar;
356          set (co,'xtick',[-40:20:40],'xticklabel',[-40:20:40],'fontname','Arial','fontsize',6);
357       end;
358       set (gca,'tickDir','out');
359       axis equal
360       axis([-180 180 -10 40]);
361
362       if e==7;
363       title('Composite geopotential + winds 200 hPa : differences min - max (mode Rossby EOF2)','fontsize',8) ;
364       end
365       text(-270,10,['day = ',num2str(f-21)],'fontname','Arial','fontsize',10);
366       pos_vert=e/10;
367       set (gca,'position',[0.2 pos_vert 0.5 0.1])
368end;
369
370status=print('-depsc2','composite_rossby_eof2a_u200_hgt.eps');
371
372figure(2);
373orient('landscape')
374status=load('pression.mat');
375
376for e=1:7;
377       a=7-(e-1)+1+7;
378       f=2*(a-1)+1;
379       clear delta_uwnd200_filtre_min;
380       clear delta_vwnd200_filtre_min;
381       delta_uwnd200_filtre_min=zeros(49,144);
382       delta_vwnd200_filtre_min=zeros(49,144);
383       for b=1:49;
384          for c=1:144;
385             delta_uwnd200_filtre_min(b,c)=uwnd200_filtre_compomin1(f,b,c)-uwnd200_filtre_compomax1(f,b,c);
386             delta_vwnd200_filtre_min(b,c)=vwnd200_filtre_compomin1(f,b,c)-vwnd200_filtre_compomax1(f,b,c);
387         end;
388       end;
389       subplot(7,1,8-e);
390
391       delta_vwnd200_filtre=zeros(49,144);
392       delta_uwnd200_filtre=zeros(49,144);
393       delta_vwnd200_filtre(:,1:72)=delta_vwnd200_filtre_min(:,73:144);
394       delta_vwnd200_filtre(:,73:144)=delta_vwnd200_filtre_min(:,1:72);
395       delta_uwnd200_filtre(:,1:72)=delta_uwnd200_filtre_min(:,73:144);
396       delta_uwnd200_filtre(:,73:144)=delta_uwnd200_filtre_min(:,1:72);
397       xi=[-180:3.75:176.25];
398       xi=xi';
399       yi=[-87.1591:3.708895:87.1591];
400       clear carteu cartev;
401       carteu=interp2(lon-180,lat,delta_uwnd200_filtre,xi,yi);
402       cartev=interp2(lon-180,lat,delta_vwnd200_filtre,xi,yi);
403       clear coco ;
404       coco(:,:)=pression(a+7,:,:);
405       hgt=interp2(lon-180,lat,coco,xi,yi);
406       palette
407       aa=contourf(xi,yi,hgt,[-50:5:50],'LineStyle','none');
408       hold on;
409       aa=quiver(xi,yi,carteu,cartev,'k');
410       if e==1;
411       set (gca,'XTick',[-180:60:180],'XTickLabel',[' 180';'120W';' 60W';'   0';' 60E';'120E';' 180'],'fontname','Arial','fontsize',6);
412       else
413      set (gca,'XTick',[-180:60:180],'XTickLabel',[' ';' ';' ';' ';' ';' '],'fontname','Arial','fontsize',6);
414       end
415       set (gca,'YTick',[-10:10:40],'YTickLabel',['   ';'  0';'10N';'20N';'30N';'   '],'fontname','Arial','fontsize',6);
416       cartemonde1;
417       if e==4;
418          co=colorbar;
419          set (co,'xtick',[-40:20:40],'xticklabel',[-40:10:40],'fontname','Arial','fontsize',6);
420       end;
421       set (gca,'tickDir','out');
422       axis equal
423       axis([-180 180 -10 40]);
424
425       if e==7;
426           title('Composite geopotential + winds 200 hPa : differences min - max (mode Rossby EOF2)','fontsize',8) ;
427
428       end
429       text(-270,10,['day = ',num2str(f-21)],'fontname','Arial','fontsize',10);
430       pos_vert=e/10;
431       set (gca,'position',[0.2 pos_vert 0.5 0.1])
432end;
433
434status=print('-depsc2','composite_rossby_eof2b_u200_hgt.eps');
Note: See TracBrowser for help on using the repository browser.