source: trunk/src/mode_sahelien/composite_wind200_sahel.m @ 15

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

modification according to mlint diagnostic

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