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

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

add semi-colon after end everywhere

File size: 20.9 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');
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
54uwnd200_filtre_compomax=NaN*ones(60,31,49,144);
55uwnd200_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            uwnd200_filtre_compomax(compteurmax,1,:,:)=uwnd(b-20,a,:,:);
78            uwnd200_filtre_compomax(compteurmax,2,:,:)=uwnd(b-19,a,:,:);
79            uwnd200_filtre_compomax(compteurmax,3,:,:)=uwnd(b-18,a,:,:);
80            uwnd200_filtre_compomax(compteurmax,4,:,:)=uwnd(b-17,a,:,:);
81            uwnd200_filtre_compomax(compteurmax,5,:,:)=uwnd(b-16,a,:,:);
82            uwnd200_filtre_compomax(compteurmax,6,:,:)=uwnd(b-15,a,:,:);
83            uwnd200_filtre_compomax(compteurmax,7,:,:)=uwnd(b-14,a,:,:);
84            uwnd200_filtre_compomax(compteurmax,8,:,:)=uwnd(b-13,a,:,:);
85            uwnd200_filtre_compomax(compteurmax,9,:,:)=uwnd(b-12,a,:,:);
86            uwnd200_filtre_compomax(compteurmax,10,:,:)=uwnd(b-11,a,:,:);
87
88            uwnd200_filtre_compomax(compteurmax,11,:,:)=uwnd(b-10,a,:,:);
89            uwnd200_filtre_compomax(compteurmax,12,:,:)=uwnd(b-9,a,:,:);
90            uwnd200_filtre_compomax(compteurmax,13,:,:)=uwnd(b-8,a,:,:);
91            uwnd200_filtre_compomax(compteurmax,14,:,:)=uwnd(b-7,a,:,:);
92            uwnd200_filtre_compomax(compteurmax,15,:,:)=uwnd(b-6,a,:,:);
93            uwnd200_filtre_compomax(compteurmax,16,:,:)=uwnd(b-5,a,:,:);
94            uwnd200_filtre_compomax(compteurmax,17,:,:)=uwnd(b-4,a,:,:);
95            uwnd200_filtre_compomax(compteurmax,18,:,:)=uwnd(b-3,a,:,:);
96            uwnd200_filtre_compomax(compteurmax,19,:,:)=uwnd(b-2,a,:,:);
97            uwnd200_filtre_compomax(compteurmax,20,:,:)=uwnd(b-1,a,:,:);
98
99            uwnd200_filtre_compomax(compteurmax,21,:,:)=uwnd(b,a,:,:);
100            uwnd200_filtre_compomax(compteurmax,22,:,:)=uwnd(b+1,a,:,:);
101            uwnd200_filtre_compomax(compteurmax,23,:,:)=uwnd(b+2,a,:,:);
102            uwnd200_filtre_compomax(compteurmax,24,:,:)=uwnd(b+3,a,:,:);
103            uwnd200_filtre_compomax(compteurmax,25,:,:)=uwnd(b+4,a,:,:);
104            uwnd200_filtre_compomax(compteurmax,26,:,:)=uwnd(b+5,a,:,:);
105            uwnd200_filtre_compomax(compteurmax,27,:,:)=uwnd(b+6,a,:,:);
106            uwnd200_filtre_compomax(compteurmax,28,:,:)=uwnd(b+7,a,:,:);
107            uwnd200_filtre_compomax(compteurmax,29,:,:)=uwnd(b+8,a,:,:);
108            uwnd200_filtre_compomax(compteurmax,30,:,:)=uwnd(b+9,a,:,:);
109            uwnd200_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            uwnd200_filtre_compomin(compteurmin,1,:,:)=uwnd(b-20,a,:,:);
115            uwnd200_filtre_compomin(compteurmin,2,:,:)=uwnd(b-19,a,:,:);
116            uwnd200_filtre_compomin(compteurmin,3,:,:)=uwnd(b-18,a,:,:);
117            uwnd200_filtre_compomin(compteurmin,4,:,:)=uwnd(b-17,a,:,:);
118            uwnd200_filtre_compomin(compteurmin,5,:,:)=uwnd(b-16,a,:,:);
119            uwnd200_filtre_compomin(compteurmin,6,:,:)=uwnd(b-15,a,:,:);
120            uwnd200_filtre_compomin(compteurmin,7,:,:)=uwnd(b-14,a,:,:);
121            uwnd200_filtre_compomin(compteurmin,8,:,:)=uwnd(b-13,a,:,:);
122            uwnd200_filtre_compomin(compteurmin,9,:,:)=uwnd(b-12,a,:,:);
123            uwnd200_filtre_compomin(compteurmin,10,:,:)=uwnd(b-11,a,:,:);
124
125            uwnd200_filtre_compomin(compteurmin,11,:,:)=uwnd(b-10,a,:,:);
126            uwnd200_filtre_compomin(compteurmin,12,:,:)=uwnd(b-9,a,:,:);
127            uwnd200_filtre_compomin(compteurmin,13,:,:)=uwnd(b-8,a,:,:);
128            uwnd200_filtre_compomin(compteurmin,14,:,:)=uwnd(b-7,a,:,:);
129            uwnd200_filtre_compomin(compteurmin,15,:,:)=uwnd(b-6,a,:,:);
130            uwnd200_filtre_compomin(compteurmin,16,:,:)=uwnd(b-5,a,:,:);
131            uwnd200_filtre_compomin(compteurmin,17,:,:)=uwnd(b-4,a,:,:);
132            uwnd200_filtre_compomin(compteurmin,18,:,:)=uwnd(b-3,a,:,:);
133            uwnd200_filtre_compomin(compteurmin,19,:,:)=uwnd(b-2,a,:,:);
134            uwnd200_filtre_compomin(compteurmin,20,:,:)=uwnd(b-1,a,:,:);
135
136            uwnd200_filtre_compomin(compteurmin,21,:,:)=uwnd(b,a,:,:);
137            uwnd200_filtre_compomin(compteurmin,22,:,:)=uwnd(b+1,a,:,:);
138            uwnd200_filtre_compomin(compteurmin,23,:,:)=uwnd(b+2,a,:,:);
139            uwnd200_filtre_compomin(compteurmin,24,:,:)=uwnd(b+3,a,:,:);
140            uwnd200_filtre_compomin(compteurmin,25,:,:)=uwnd(b+4,a,:,:);
141            uwnd200_filtre_compomin(compteurmin,26,:,:)=uwnd(b+5,a,:,:);
142            uwnd200_filtre_compomin(compteurmin,27,:,:)=uwnd(b+6,a,:,:);
143            uwnd200_filtre_compomin(compteurmin,28,:,:)=uwnd(b+7,a,:,:);
144            uwnd200_filtre_compomin(compteurmin,29,:,:)=uwnd(b+8,a,:,:);
145            uwnd200_filtre_compomin(compteurmin,30,:,:)=uwnd(b+9,a,:,:);
146            uwnd200_filtre_compomin(compteurmin,31,:,:)=uwnd(b+10,a,:,:);
147         end;
148      end;
149   end;
150end;
151
152% on fait la somme des valeurs de uwnd200_filtreentiel sur le nbre d occurences
153% on obtent un tableau de la forme (jours-avant-apres,lon,lat)
154uwnd200_filtre_compomin1(:,:,:)=nanmean(uwnd200_filtre_compomin);
155clear uwnd200_filtre_compomin;
156uwnd200_filtre_compomax1(:,:,:)=nanmean(uwnd200_filtre_compomax);
157clear uwnd200_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
162vwnd200=zeros(122,49,144,22);
163
164siz=31+28+31+30+31+1;
165sizbis=31+28+31+30+31+30+31+31+30;
166ncload('vwnd200.1979.nc'); vwnd200(:,:,:,1)=vwnd(siz:sizbis,1,:,:); clear vwnd;
167ncload('vwnd200.1980.nc'); vwnd200(:,:,:,2)=vwnd(siz+1:sizbis+1,1,:,:); clear vwnd;
168ncload('vwnd200.1981.nc'); vwnd200(:,:,:,3)=vwnd(siz:sizbis,1,:,:);clear vwnd;
169ncload('vwnd200.1982.nc'); vwnd200(:,:,:,4)=vwnd(siz:sizbis,1,:,:);clear vwnd;
170ncload('vwnd200.1983.nc'); vwnd200(:,:,:,5)=vwnd(siz:sizbis,1,:,:);clear vwnd;
171ncload('vwnd200.1984.nc'); vwnd200(:,:,:,6)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
172ncload('vwnd200.1985.nc'); vwnd200(:,:,:,7)=vwnd(siz:sizbis,1,:,:);clear vwnd;
173ncload('vwnd200.1986.nc'); vwnd200(:,:,:,8)=vwnd(siz:sizbis,1,:,:);clear vwnd;
174ncload('vwnd200.1987.nc'); vwnd200(:,:,:,9)=vwnd(siz:sizbis,1,:,:);clear vwnd;
175ncload('vwnd200.1988.nc'); vwnd200(:,:,:,10)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
176ncload('vwnd200.1989.nc'); vwnd200(:,:,:,11)=vwnd(siz:sizbis,1,:,:);clear vwnd;
177ncload('vwnd200.1990.nc'); vwnd200(:,:,:,12)=vwnd(siz:sizbis,1,:,:);clear vwnd;
178ncload('vwnd200.1991.nc'); vwnd200(:,:,:,13)=vwnd(siz:sizbis,1,:,:);clear vwnd;
179ncload('vwnd200.1992.nc'); vwnd200(:,:,:,14)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
180ncload('vwnd200.1993.nc'); vwnd200(:,:,:,15)=vwnd(siz:sizbis,1,:,:);clear vwnd;
181ncload('vwnd200.1994.nc'); vwnd200(:,:,:,16)=vwnd(siz:sizbis,1,:,:);clear vwnd;
182ncload('vwnd200.1995.nc'); vwnd200(:,:,:,17)=vwnd(siz:sizbis,1,:,:);clear vwnd;
183ncload('vwnd200.1996.nc'); vwnd200(:,:,:,18)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
184ncload('vwnd200.1997.nc'); vwnd200(:,:,:,19)=vwnd(siz:sizbis,1,:,:);clear vwnd;
185ncload('vwnd200.1998.nc'); vwnd200(:,:,:,20)=vwnd(siz:sizbis,1,:,:);clear vwnd;
186ncload('vwnd200.1999.nc'); vwnd200(:,:,:,21)=vwnd(siz:sizbis,1,:,:);clear vwnd;
187ncload('vwnd200.2000.nc'); vwnd200(:,:,:,22)=vwnd(siz+1:sizbis+1,1,:,:);clear vwnd;
188clear siz1 siz1bis;
189
190vwnd=permute(vwnd200,[1 4 2 3]);
191clear vwnd200;
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
204vwnd200_filtre_compomax=NaN*ones(60,31,49,144);
205vwnd200_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            vwnd200_filtre_compomax(compteurmax,1,:,:)=vwnd(b-20,a,:,:);
228            vwnd200_filtre_compomax(compteurmax,2,:,:)=vwnd(b-19,a,:,:);
229            vwnd200_filtre_compomax(compteurmax,3,:,:)=vwnd(b-18,a,:,:);
230            vwnd200_filtre_compomax(compteurmax,4,:,:)=vwnd(b-17,a,:,:);
231            vwnd200_filtre_compomax(compteurmax,5,:,:)=vwnd(b-16,a,:,:);
232            vwnd200_filtre_compomax(compteurmax,6,:,:)=vwnd(b-15,a,:,:);
233            vwnd200_filtre_compomax(compteurmax,7,:,:)=vwnd(b-14,a,:,:);
234            vwnd200_filtre_compomax(compteurmax,8,:,:)=vwnd(b-13,a,:,:);
235            vwnd200_filtre_compomax(compteurmax,9,:,:)=vwnd(b-12,a,:,:);
236            vwnd200_filtre_compomax(compteurmax,10,:,:)=vwnd(b-11,a,:,:);
237
238            vwnd200_filtre_compomax(compteurmax,11,:,:)=vwnd(b-10,a,:,:);
239            vwnd200_filtre_compomax(compteurmax,12,:,:)=vwnd(b-9,a,:,:);
240            vwnd200_filtre_compomax(compteurmax,13,:,:)=vwnd(b-8,a,:,:);
241            vwnd200_filtre_compomax(compteurmax,14,:,:)=vwnd(b-7,a,:,:);
242            vwnd200_filtre_compomax(compteurmax,15,:,:)=vwnd(b-6,a,:,:);
243            vwnd200_filtre_compomax(compteurmax,16,:,:)=vwnd(b-5,a,:,:);
244            vwnd200_filtre_compomax(compteurmax,17,:,:)=vwnd(b-4,a,:,:);
245            vwnd200_filtre_compomax(compteurmax,18,:,:)=vwnd(b-3,a,:,:);
246            vwnd200_filtre_compomax(compteurmax,19,:,:)=vwnd(b-2,a,:,:);
247            vwnd200_filtre_compomax(compteurmax,20,:,:)=vwnd(b-1,a,:,:);
248
249            vwnd200_filtre_compomax(compteurmax,21,:,:)=vwnd(b,a,:,:);
250            vwnd200_filtre_compomax(compteurmax,22,:,:)=vwnd(b+1,a,:,:);
251            vwnd200_filtre_compomax(compteurmax,23,:,:)=vwnd(b+2,a,:,:);
252            vwnd200_filtre_compomax(compteurmax,24,:,:)=vwnd(b+3,a,:,:);
253            vwnd200_filtre_compomax(compteurmax,25,:,:)=vwnd(b+4,a,:,:);
254            vwnd200_filtre_compomax(compteurmax,26,:,:)=vwnd(b+5,a,:,:);
255            vwnd200_filtre_compomax(compteurmax,27,:,:)=vwnd(b+6,a,:,:);
256            vwnd200_filtre_compomax(compteurmax,28,:,:)=vwnd(b+7,a,:,:);
257            vwnd200_filtre_compomax(compteurmax,29,:,:)=vwnd(b+8,a,:,:);
258            vwnd200_filtre_compomax(compteurmax,30,:,:)=vwnd(b+9,a,:,:);
259            vwnd200_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            vwnd200_filtre_compomin(compteurmin,1,:,:)=vwnd(b-20,a,:,:);
265            vwnd200_filtre_compomin(compteurmin,2,:,:)=vwnd(b-19,a,:,:);
266            vwnd200_filtre_compomin(compteurmin,3,:,:)=vwnd(b-18,a,:,:);
267            vwnd200_filtre_compomin(compteurmin,4,:,:)=vwnd(b-17,a,:,:);
268            vwnd200_filtre_compomin(compteurmin,5,:,:)=vwnd(b-16,a,:,:);
269            vwnd200_filtre_compomin(compteurmin,6,:,:)=vwnd(b-15,a,:,:);
270            vwnd200_filtre_compomin(compteurmin,7,:,:)=vwnd(b-14,a,:,:);
271            vwnd200_filtre_compomin(compteurmin,8,:,:)=vwnd(b-13,a,:,:);
272            vwnd200_filtre_compomin(compteurmin,9,:,:)=vwnd(b-12,a,:,:);
273            vwnd200_filtre_compomin(compteurmin,10,:,:)=vwnd(b-11,a,:,:);
274
275            vwnd200_filtre_compomin(compteurmin,11,:,:)=vwnd(b-10,a,:,:);
276            vwnd200_filtre_compomin(compteurmin,12,:,:)=vwnd(b-9,a,:,:);
277            vwnd200_filtre_compomin(compteurmin,13,:,:)=vwnd(b-8,a,:,:);
278            vwnd200_filtre_compomin(compteurmin,14,:,:)=vwnd(b-7,a,:,:);
279            vwnd200_filtre_compomin(compteurmin,15,:,:)=vwnd(b-6,a,:,:);
280            vwnd200_filtre_compomin(compteurmin,16,:,:)=vwnd(b-5,a,:,:);
281            vwnd200_filtre_compomin(compteurmin,17,:,:)=vwnd(b-4,a,:,:);
282            vwnd200_filtre_compomin(compteurmin,18,:,:)=vwnd(b-3,a,:,:);
283            vwnd200_filtre_compomin(compteurmin,19,:,:)=vwnd(b-2,a,:,:);
284            vwnd200_filtre_compomin(compteurmin,20,:,:)=vwnd(b-1,a,:,:);
285
286            vwnd200_filtre_compomin(compteurmin,21,:,:)=vwnd(b,a,:,:);
287            vwnd200_filtre_compomin(compteurmin,22,:,:)=vwnd(b+1,a,:,:);
288            vwnd200_filtre_compomin(compteurmin,23,:,:)=vwnd(b+2,a,:,:);
289            vwnd200_filtre_compomin(compteurmin,24,:,:)=vwnd(b+3,a,:,:);
290            vwnd200_filtre_compomin(compteurmin,25,:,:)=vwnd(b+4,a,:,:);
291            vwnd200_filtre_compomin(compteurmin,26,:,:)=vwnd(b+5,a,:,:);
292            vwnd200_filtre_compomin(compteurmin,27,:,:)=vwnd(b+6,a,:,:);
293            vwnd200_filtre_compomin(compteurmin,28,:,:)=vwnd(b+7,a,:,:);
294            vwnd200_filtre_compomin(compteurmin,29,:,:)=vwnd(b+8,a,:,:);
295            vwnd200_filtre_compomin(compteurmin,30,:,:)=vwnd(b+9,a,:,:);
296            vwnd200_filtre_compomin(compteurmin,31,:,:)=vwnd(b+10,a,:,:);
297         end;
298      end;
299   end;
300end;
301
302% on fait la somme des valeurs de vwnd200_filtreentiel sur le nbre d occurences
303% on obtent un tableau de la forme (jours-avant-apres,lon,lat)
304vwnd200_filtre_compomin1(:,:,:)=nanmean(vwnd200_filtre_compomin);
305clear vwnd200_filtre_compomin;
306vwnd200_filtre_compomax1(:,:,:)=nanmean(vwnd200_filtre_compomax);
307clear vwnd200_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_uwnd200_filtre_min;
320       clear delta_vwnd200_filtre_min;
321       delta_uwnd200_filtre_min=zeros(49,144);
322       delta_vwnd200_filtre_min=zeros(49,144);
323       for b=1:49;
324          for c=1:144;
325             delta_uwnd200_filtre_min(b,c)=uwnd200_filtre_compomin1(f,b,c)-uwnd200_filtre_compomax1(f,b,c);
326             delta_vwnd200_filtre_min(b,c)=vwnd200_filtre_compomin1(f,b,c)-vwnd200_filtre_compomax1(f,b,c);
327
328         end;
329       end;
330       subplot(7,1,8-e);
331
332       delta_vwnd200_filtre=zeros(49,144);
333       delta_uwnd200_filtre=zeros(49,144);
334       delta_vwnd200_filtre(:,1:72)=delta_vwnd200_filtre_min(:,73:144);
335       delta_vwnd200_filtre(:,73:144)=delta_vwnd200_filtre_min(:,1:72);
336       delta_uwnd200_filtre(:,1:72)=delta_uwnd200_filtre_min(:,73:144);
337       delta_uwnd200_filtre(:,73:144)=delta_uwnd200_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_uwnd200_filtre,xi,yi);
343       cartev=interp2(lon-180,lat,delta_vwnd200_filtre,xi,yi);
344       clear coco ;
345       coco(:,:)=pression(a,:,:);
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',[-180:60:180],'XTickLabel',[' 180';'120W';' 60W';'   0';' 60E';'120E';' 180'],'fontname','Arial','fontsize',6);
353       else
354      set (gca,'XTick',[-180:60:180],'XTickLabel',[' ';' ';' ';' ';' ';' '],'fontname','Arial','fontsize',6);
355       end;
356       set (gca,'YTick',[-10:10:40],'YTickLabel',['   ';'  0';'10N';'20N';'30N';'   '],'fontname','Arial','fontsize',6);
357       cartemonde1;
358       if e==4;
359          co=colorbar;
360          set (co,'xtick',[-40:20:40],'xticklabel',[-40:20:40],'fontname','Arial','fontsize',6);
361       end;
362       set (gca,'tickDir','out');
363       axis equal
364       axis([-180 180 -10 40]);
365
366       if e==7;
367       title('Composite geopotential + winds 200 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_u200_hgt.eps');
375
376figure(2);
377orient('landscape')
378status=load('pression.mat','pression');
379pression=status.pression;
380clear status;
381
382for e=1:7;
383       a=7-(e-1)+1+7;
384       f=2*(a-1)+1;
385       clear delta_uwnd200_filtre_min;
386       clear delta_vwnd200_filtre_min;
387       delta_uwnd200_filtre_min=zeros(49,144);
388       delta_vwnd200_filtre_min=zeros(49,144);
389       for b=1:49;
390          for c=1:144;
391             delta_uwnd200_filtre_min(b,c)=uwnd200_filtre_compomin1(f,b,c)-uwnd200_filtre_compomax1(f,b,c);
392             delta_vwnd200_filtre_min(b,c)=vwnd200_filtre_compomin1(f,b,c)-vwnd200_filtre_compomax1(f,b,c);
393         end;
394       end;
395       subplot(7,1,8-e);
396
397       delta_vwnd200_filtre=zeros(49,144);
398       delta_uwnd200_filtre=zeros(49,144);
399       delta_vwnd200_filtre(:,1:72)=delta_vwnd200_filtre_min(:,73:144);
400       delta_vwnd200_filtre(:,73:144)=delta_vwnd200_filtre_min(:,1:72);
401       delta_uwnd200_filtre(:,1:72)=delta_uwnd200_filtre_min(:,73:144);
402       delta_uwnd200_filtre(:,73:144)=delta_uwnd200_filtre_min(:,1:72);
403       xi=[-180:3.75:176.25];
404       xi=xi';
405       yi=[-87.1591:3.708895:87.1591];
406       clear carteu cartev;
407       carteu=interp2(lon-180,lat,delta_uwnd200_filtre,xi,yi);
408       cartev=interp2(lon-180,lat,delta_vwnd200_filtre,xi,yi);
409       clear coco ;
410       coco(:,:)=pression(a+7,:,:);
411       hgt=interp2(lon-180,lat,coco,xi,yi);
412       palette
413       aa=contourf(xi,yi,hgt,[-50:5:50],'LineStyle','none');
414       hold on;
415       aa=quiver(xi,yi,carteu,cartev,'k');
416       if e==1;
417       set (gca,'XTick',[-180:60:180],'XTickLabel',[' 180';'120W';' 60W';'   0';' 60E';'120E';' 180'],'fontname','Arial','fontsize',6);
418       else
419      set (gca,'XTick',[-180:60:180],'XTickLabel',[' ';' ';' ';' ';' ';' '],'fontname','Arial','fontsize',6);
420       end;
421       set (gca,'YTick',[-10:10:40],'YTickLabel',['   ';'  0';'10N';'20N';'30N';'   '],'fontname','Arial','fontsize',6);
422       cartemonde1;
423       if e==4;
424          co=colorbar;
425          set (co,'xtick',[-40:20:40],'xticklabel',[-40:10:40],'fontname','Arial','fontsize',6);
426       end;
427       set (gca,'tickDir','out');
428       axis equal
429       axis([-180 180 -10 40]);
430
431       if e==7;
432           title('Composite geopotential + winds 200 hPa : differences min - max (mode Rossby EOF2)','fontsize',8) ;
433
434       end;
435       text(-270,10,['day = ',num2str(f-21)],'fontname','Arial','fontsize',10);
436       pos_vert=e/10;
437       set (gca,'position',[0.2 pos_vert 0.5 0.1])
438end;
439
440print('-depsc2','composite_rossby_eof2b_u200_hgt.eps');
Note: See TracBrowser for help on using the repository browser.