source: trunk/src/mode_sahelien/composite_wind500_rossby_europe.m @ 91

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

add semi-colon after end everywhere

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