Statistiques
| Révision :

root / TrouNoir / trou_noir.c @ 305

Historique | Voir | Annoter | Télécharger (10,14 ko)

1 197 equemene
/*
2 197 equemene
        Programme original realise en Fortran 77 en mars 1994
3 197 equemene
        pour les Travaux Pratiques de Modelisation Numerique
4 197 equemene
        DEA d'astrophysique et techniques spatiales de Meudon
5 197 equemene

6 197 equemene
                par Herve Aussel et Emmanuel Quemener
7 197 equemene

8 197 equemene
        Conversion en C par Emmanuel Quemener en aout 1997
9 214 equemene
        Modification par Emmanuel Quemener en aout 2019
10 197 equemene

11 258 equemene
        Licence CC BY-NC-SA Emmanuel QUEMENER <emmanuel.quemener@gmail.com>
12 258 equemene

13 197 equemene
        Remerciements a :
14 197 equemene

15 197 equemene
        - Herve Aussel pour sa procedure sur le spectre de corps noir
16 197 equemene
        - Didier Pelat pour l'aide lors de ce travail
17 197 equemene
        - Jean-Pierre Luminet pour son article de 1979
18 197 equemene
        - Le Numerical Recipies pour ses recettes de calcul
19 197 equemene
        - Luc Blanchet pour sa disponibilite lors de mes interrogations en RG
20 197 equemene

21 197 equemene
        Compilation sous gcc ( Compilateur GNU sous Linux ) :
22 197 equemene

23 292 equemene
        Version FP32 :        gcc -Ofast -DFP32 -o trou_noir_FP32 trou_noir.c -lm
24 292 equemene
        Version FP64 :        gcc -Ofast -DFP64 -o trou_noir_FP64 trou_noir.c -lm
25 197 equemene
*/
26 197 equemene
27 197 equemene
#include <stdio.h>
28 197 equemene
#include <math.h>
29 197 equemene
#include <stdlib.h>
30 197 equemene
#include <string.h>
31 214 equemene
#include <sys/time.h>
32 215 equemene
#include <time.h>
33 197 equemene
34 214 equemene
#define nbr 256 /* Nombre de colonnes du spectre */
35 197 equemene
36 197 equemene
#define PI 3.14159265359
37 197 equemene
38 214 equemene
#define TRACKPOINTS 2048
39 214 equemene
40 231 equemene
#if TYPE == FP64
41 231 equemene
#define MYFLOAT double
42 231 equemene
#else
43 214 equemene
#define MYFLOAT float
44 214 equemene
#endif
45 214 equemene
46 214 equemene
MYFLOAT atanp(MYFLOAT x,MYFLOAT y)
47 197 equemene
{
48 214 equemene
  MYFLOAT angle;
49 197 equemene
50 197 equemene
  angle=atan2(y,x);
51 197 equemene
52 197 equemene
  if (angle<0)
53 197 equemene
    {
54 197 equemene
      angle+=2*PI;
55 197 equemene
    }
56 197 equemene
57 197 equemene
  return angle;
58 197 equemene
}
59 197 equemene
60 197 equemene
61 214 equemene
MYFLOAT f(MYFLOAT v)
62 197 equemene
{
63 197 equemene
  return v;
64 197 equemene
}
65 197 equemene
66 214 equemene
MYFLOAT g(MYFLOAT u,MYFLOAT m,MYFLOAT b)
67 197 equemene
{
68 197 equemene
  return (3.*m/b*pow(u,2)-u);
69 197 equemene
}
70 197 equemene
71 197 equemene
72 214 equemene
void calcul(MYFLOAT *us,MYFLOAT *vs,MYFLOAT up,MYFLOAT vp,
73 214 equemene
            MYFLOAT h,MYFLOAT m,MYFLOAT b)
74 197 equemene
{
75 214 equemene
  MYFLOAT c[4],d[4];
76 197 equemene
77 197 equemene
  c[0]=h*f(vp);
78 197 equemene
  c[1]=h*f(vp+c[0]/2.);
79 197 equemene
  c[2]=h*f(vp+c[1]/2.);
80 197 equemene
  c[3]=h*f(vp+c[2]);
81 197 equemene
  d[0]=h*g(up,m,b);
82 197 equemene
  d[1]=h*g(up+d[0]/2.,m,b);
83 197 equemene
  d[2]=h*g(up+d[1]/2.,m,b);
84 197 equemene
  d[3]=h*g(up+d[2],m,b);
85 197 equemene
86 197 equemene
  *us=up+(c[0]+2.*c[1]+2.*c[2]+c[3])/6.;
87 197 equemene
  *vs=vp+(d[0]+2.*d[1]+2.*d[2]+d[3])/6.;
88 197 equemene
}
89 197 equemene
90 214 equemene
void rungekutta(MYFLOAT *ps,MYFLOAT *us,MYFLOAT *vs,
91 214 equemene
                MYFLOAT pp,MYFLOAT up,MYFLOAT vp,
92 214 equemene
                MYFLOAT h,MYFLOAT m,MYFLOAT b)
93 197 equemene
{
94 197 equemene
  calcul(us,vs,up,vp,h,m,b);
95 197 equemene
  *ps=pp+h;
96 197 equemene
}
97 197 equemene
98 197 equemene
99 214 equemene
MYFLOAT decalage_spectral(MYFLOAT r,MYFLOAT b,MYFLOAT phi,
100 214 equemene
                         MYFLOAT tho,MYFLOAT m)
101 197 equemene
{
102 197 equemene
  return (sqrt(1-3*m/r)/(1+sqrt(m/pow(r,3))*b*sin(tho)*sin(phi)));
103 197 equemene
}
104 197 equemene
105 214 equemene
MYFLOAT spectre(MYFLOAT rf,MYFLOAT q,MYFLOAT b,MYFLOAT db,
106 214 equemene
             MYFLOAT h,MYFLOAT r,MYFLOAT m,MYFLOAT bss)
107 197 equemene
{
108 214 equemene
  MYFLOAT flx;
109 197 equemene
110 214 equemene
  flx=exp(q*log(r/m))*pow(rf,4)*b*db*h;
111 214 equemene
  return(flx);
112 197 equemene
}
113 197 equemene
114 214 equemene
MYFLOAT spectre_cn(MYFLOAT rf,MYFLOAT b,MYFLOAT db,
115 214 equemene
                MYFLOAT h,MYFLOAT r,MYFLOAT m,MYFLOAT bss)
116 197 equemene
{
117 214 equemene
118 214 equemene
  MYFLOAT flx;
119 214 equemene
  MYFLOAT nu_rec,nu_em,qu,temp_em,flux_int;
120 197 equemene
  int fi,posfreq;
121 197 equemene
122 214 equemene
#define planck 6.62e-34
123 214 equemene
#define k 1.38e-23
124 214 equemene
#define c2 9.e16
125 214 equemene
#define temp 3.e7
126 214 equemene
#define m_point 1.
127 197 equemene
128 214 equemene
#define lplanck (log(6.62)-34.*log(10.))
129 214 equemene
#define lk (log(1.38)-23.*log(10.))
130 214 equemene
#define lc2 (log(9.)+16.*log(10.))
131 214 equemene
132 214 equemene
  MYFLOAT v=1.-3./r;
133 197 equemene
134 214 equemene
  qu=1./sqrt((1.-3./r)*r)*(sqrt(r)-sqrt(6.)+sqrt(3.)/2.*log((sqrt(r)+sqrt(3.))/(sqrt(r)-sqrt(3.))* 0.17157287525380988 ));
135 197 equemene
136 214 equemene
  temp_em=temp*sqrt(m)*exp(0.25*log(m_point)-0.75*log(r)-0.125*log(v)+0.25*log(fabs(qu)));
137 197 equemene
138 214 equemene
  flux_int=0.;
139 214 equemene
  flx=0.;
140 214 equemene
141 214 equemene
  for (fi=0;fi<nbr;fi++)
142 197 equemene
    {
143 214 equemene
      nu_em=bss*(MYFLOAT)fi/(MYFLOAT)nbr;
144 214 equemene
      nu_rec=nu_em*rf;
145 214 equemene
      posfreq=(int)(nu_rec*(MYFLOAT)nbr/bss);
146 197 equemene
      if ((posfreq>0)&&(posfreq<nbr))
147 214 equemene
          {
148 214 equemene
          flux_int=2.*planck/c2*pow(nu_em,3)/(exp(planck*nu_em/(k*temp_em))-1.)*exp(3.*log(rf))*b*db*h;
149 214 equemene
            flx+=flux_int;
150 214 equemene
          }
151 197 equemene
    }
152 214 equemene
153 214 equemene
  return((MYFLOAT)flx);
154 197 equemene
}
155 197 equemene
156 214 equemene
void impact(MYFLOAT d,MYFLOAT phi,int dim,MYFLOAT r,MYFLOAT b,MYFLOAT tho,MYFLOAT m,
157 304 equemene
            MYFLOAT *zp,MYFLOAT *fp,
158 214 equemene
            MYFLOAT q,MYFLOAT db,
159 214 equemene
            MYFLOAT h,MYFLOAT bss,int raie)
160 197 equemene
{
161 214 equemene
  MYFLOAT xe,ye;
162 197 equemene
  int xi,yi;
163 214 equemene
  MYFLOAT flx,rf;
164 197 equemene
  xe=d*sin(phi);
165 197 equemene
  ye=-d*cos(phi);
166 197 equemene
167 197 equemene
  xi=(int)xe+dim/2;
168 197 equemene
  yi=(int)ye+dim/2;
169 197 equemene
170 197 equemene
  rf=decalage_spectral(r,b,phi,tho,m);
171 197 equemene
172 197 equemene
  if (raie==0)
173 197 equemene
    {
174 214 equemene
      bss=1.e19;
175 214 equemene
      flx=spectre_cn(rf,b,db,h,r,m,bss);
176 197 equemene
    }
177 197 equemene
  else
178 197 equemene
    {
179 214 equemene
      bss=2.;
180 214 equemene
      flx=spectre(rf,q,b,db,h,r,m,bss);
181 197 equemene
    }
182 197 equemene
183 304 equemene
  if (zp[xi+dim*yi]==0.)
184 197 equemene
    {
185 304 equemene
      zp[xi+dim*yi]=1./rf;
186 197 equemene
    }
187 197 equemene
188 304 equemene
  if (fp[xi+dim*yi]==0.)
189 197 equemene
    {
190 304 equemene
      fp[xi+dim*yi]=flx;
191 197 equemene
    }
192 214 equemene
193 197 equemene
}
194 197 equemene
195 304 equemene
void sauvegarde_pgm(char nom[24],unsigned int *image,int dim)
196 197 equemene
{
197 197 equemene
  FILE            *sortie;
198 197 equemene
  unsigned long   i,j;
199 197 equemene
200 197 equemene
  sortie=fopen(nom,"w");
201 197 equemene
202 197 equemene
  fprintf(sortie,"P5\n");
203 197 equemene
  fprintf(sortie,"%i %i\n",dim,dim);
204 197 equemene
  fprintf(sortie,"255\n");
205 197 equemene
206 197 equemene
  for (j=0;j<dim;j++) for (i=0;i<dim;i++)
207 197 equemene
    {
208 304 equemene
      fputc(image[i+dim*j],sortie);
209 197 equemene
    }
210 197 equemene
211 197 equemene
  fclose(sortie);
212 197 equemene
}
213 197 equemene
214 197 equemene
int main(int argc,char *argv[])
215 197 equemene
{
216 197 equemene
217 214 equemene
  MYFLOAT m,rs,ri,re,tho;
218 197 equemene
  int q;
219 197 equemene
220 214 equemene
  MYFLOAT bss,stp;
221 197 equemene
  int nmx,dim;
222 214 equemene
  MYFLOAT d,bmx,db,b,h;
223 214 equemene
  MYFLOAT up,vp,pp;
224 214 equemene
  MYFLOAT us,vs,ps;
225 214 equemene
  MYFLOAT rp[TRACKPOINTS];
226 304 equemene
  MYFLOAT *zp,*fp;
227 304 equemene
  unsigned int *izp,*ifp;
228 230 equemene
  MYFLOAT zmx,fmx;
229 214 equemene
  int zimx=0,zjmx=0,fimx=0,fjmx=0;
230 230 equemene
  MYFLOAT phi,phd,php,nr,r;
231 230 equemene
  int ni,ii,i,imx,j,n,tst,raie,fcl,zcl;
232 214 equemene
  MYFLOAT nh;
233 214 equemene
  struct timeval tv1,tv2;
234 231 equemene
  MYFLOAT elapsed,cputime,epoch;
235 215 equemene
  int mtv1,mtv2;
236 231 equemene
  unsigned int epoch1,epoch2;
237 214 equemene
238 197 equemene
  if (argc==2)
239 197 equemene
    {
240 197 equemene
      if (strcmp(argv[1],"-aide")==0)
241 197 equemene
        {
242 197 equemene
          printf("\nSimulation d'un disque d'accretion autour d'un trou noir\n");
243 197 equemene
          printf("\nParametres a definir :\n\n");
244 214 equemene
          printf("  1) Dimension de l'Image\n");
245 214 equemene
          printf("  2) Masse relative du trou noir\n");
246 214 equemene
          printf("  3) Dimension du disque exterieur\n");
247 214 equemene
          printf("  4) Inclinaison par rapport au disque (en degres)\n");
248 214 equemene
          printf("  5) Rayonnement de disque MONOCHROMATIQUE ou CORPS_NOIR\n");
249 214 equemene
          printf("  6) Impression des images NEGATIVE ou POSITIVE\n");
250 214 equemene
          printf("  7) Nom de l'image des Flux\n");
251 214 equemene
          printf("  8) Nom de l'image des decalages spectraux\n");
252 197 equemene
          printf("\nSi aucun parametre defini, parametres par defaut :\n\n");
253 214 equemene
          printf("  1) Dimension de l'image : 1024 pixels de cote\n");
254 214 equemene
          printf("  2) Masse relative du trou noir : 1\n");
255 214 equemene
          printf("  3) Dimension du disque exterieur : 12 \n");
256 214 equemene
          printf("  4) Inclinaison par rapport au disque (en degres) : 10\n");
257 214 equemene
          printf("  5) Rayonnement de disque CORPS_NOIR\n");
258 214 equemene
          printf("  6) Impression des images NEGATIVE ou POSITIVE\n");
259 214 equemene
                 printf("  7) Nom de l'image des flux : flux.pgm\n");
260 214 equemene
          printf("  8) Nom de l'image des z : z.pgm\n");
261 197 equemene
        }
262 197 equemene
    }
263 197 equemene
264 214 equemene
  if (argc==9)
265 197 equemene
    {
266 197 equemene
      printf("# Utilisation les valeurs definies par l'utilisateur\n");
267 197 equemene
268 197 equemene
      dim=atoi(argv[1]);
269 197 equemene
      m=atof(argv[2]);
270 197 equemene
      re=atof(argv[3]);
271 214 equemene
      tho=PI/180.*(90-atof(argv[4]));
272 197 equemene
273 197 equemene
      rs=2.*m;
274 197 equemene
      ri=3.*rs;
275 197 equemene
276 214 equemene
      if (strcmp(argv[5],"CORPS_NOIR")==0)
277 197 equemene
        {
278 197 equemene
          raie=0;
279 197 equemene
        }
280 197 equemene
      else
281 197 equemene
        {
282 197 equemene
          raie=1;
283 197 equemene
        }
284 197 equemene
285 197 equemene
    }
286 197 equemene
  else
287 197 equemene
    {
288 197 equemene
      printf("# Utilisation les valeurs par defaut\n");
289 197 equemene
290 214 equemene
      dim=1024;
291 197 equemene
      m=1.;
292 197 equemene
      rs=2.*m;
293 197 equemene
      ri=3.*rs;
294 197 equemene
      re=12.;
295 197 equemene
      tho=PI/180.*80;
296 214 equemene
      // Corps noir
297 197 equemene
      raie=0;
298 197 equemene
    }
299 214 equemene
300 214 equemene
  if (raie==1)
301 214 equemene
    {
302 214 equemene
      bss=2.;
303 214 equemene
      q=-2;
304 214 equemene
    }
305 214 equemene
  else
306 214 equemene
    {
307 214 equemene
      bss=1.e19;
308 214 equemene
      q=-0.75;
309 214 equemene
    }
310 214 equemene
311 197 equemene
      printf("# Dimension de l'image : %i\n",dim);
312 197 equemene
      printf("# Masse : %f\n",m);
313 197 equemene
      printf("# Rayon singularite : %f\n",rs);
314 197 equemene
      printf("# Rayon interne : %f\n",ri);
315 197 equemene
      printf("# Rayon externe : %f\n",re);
316 197 equemene
      printf("# Inclinaison a la normale en radian : %f\n",tho);
317 197 equemene
318 304 equemene
  zp=(MYFLOAT*)calloc(dim*dim,sizeof(MYFLOAT));
319 304 equemene
  fp=(MYFLOAT*)calloc(dim*dim,sizeof(MYFLOAT));
320 197 equemene
321 304 equemene
  izp=(unsigned int*)calloc(dim*dim,sizeof(unsigned int));
322 304 equemene
  ifp=(unsigned int*)calloc(dim*dim,sizeof(unsigned int));
323 197 equemene
324 197 equemene
  nmx=dim;
325 197 equemene
  stp=dim/(2.*nmx);
326 197 equemene
  bmx=1.25*re;
327 197 equemene
  b=0.;
328 197 equemene
329 214 equemene
  // Set start timer
330 230 equemene
  gettimeofday(&tv1, NULL);
331 215 equemene
  mtv1=clock()*1000/CLOCKS_PER_SEC;
332 231 equemene
  epoch1=time(NULL);
333 215 equemene
334 197 equemene
  for (n=1;n<=nmx;n++)
335 197 equemene
    {
336 214 equemene
      h=4.*PI/(MYFLOAT)TRACKPOINTS;
337 197 equemene
      d=stp*n;
338 197 equemene
339 214 equemene
      db=bmx/(MYFLOAT)nmx;
340 214 equemene
      b=db*(MYFLOAT)n;
341 214 equemene
      up=0.;
342 214 equemene
      vp=1.;
343 197 equemene
344 197 equemene
      pp=0.;
345 197 equemene
      nh=1;
346 197 equemene
347 197 equemene
      rungekutta(&ps,&us,&vs,pp,up,vp,h,m,b);
348 197 equemene
349 197 equemene
      rp[(int)nh]=fabs(b/us);
350 197 equemene
351 197 equemene
      do
352 197 equemene
        {
353 197 equemene
          nh++;
354 197 equemene
          pp=ps;
355 197 equemene
          up=us;
356 197 equemene
          vp=vs;
357 197 equemene
          rungekutta(&ps,&us,&vs,pp,up,vp,h,m,b);
358 197 equemene
359 197 equemene
          rp[(int)nh]=b/us;
360 197 equemene
361 197 equemene
        } while ((rp[(int)nh]>=rs)&&(rp[(int)nh]<=rp[1]));
362 197 equemene
363 214 equemene
      for (i=nh+1;i<TRACKPOINTS;i++)
364 197 equemene
        {
365 197 equemene
          rp[i]=0.;
366 197 equemene
        }
367 197 equemene
368 197 equemene
      imx=(int)(8*d);
369 197 equemene
370 197 equemene
      for (i=0;i<=imx;i++)
371 197 equemene
        {
372 214 equemene
          phi=2.*PI/(MYFLOAT)imx*(MYFLOAT)i;
373 197 equemene
          phd=atanp(cos(phi)*sin(tho),cos(tho));
374 197 equemene
          phd=fmod(phd,PI);
375 197 equemene
          ii=0;
376 197 equemene
          tst=0;
377 197 equemene
378 197 equemene
          do
379 197 equemene
            {
380 214 equemene
              php=phd+(MYFLOAT)ii*PI;
381 197 equemene
              nr=php/h;
382 197 equemene
              ni=(int)nr;
383 197 equemene
384 214 equemene
              if ((MYFLOAT)ni<nh)
385 197 equemene
                {
386 197 equemene
                  r=(rp[ni+1]-rp[ni])*(nr-ni*1.)+rp[ni];
387 197 equemene
                }
388 197 equemene
              else
389 197 equemene
                {
390 197 equemene
                  r=rp[ni];
391 197 equemene
                }
392 197 equemene
393 197 equemene
              if ((r<=re)&&(r>=ri))
394 197 equemene
                {
395 197 equemene
                  tst=1;
396 214 equemene
                  impact(d,phi,dim,r,b,tho,m,zp,fp,q,db,h,bss,raie);
397 197 equemene
                }
398 197 equemene
399 197 equemene
              ii++;
400 197 equemene
            } while ((ii<=2)&&(tst==0));
401 197 equemene
        }
402 197 equemene
    }
403 197 equemene
404 214 equemene
  // Set stop timer
405 230 equemene
  gettimeofday(&tv2, NULL);
406 215 equemene
  mtv2=clock()*1000/CLOCKS_PER_SEC;
407 231 equemene
  epoch2=time(NULL);
408 231 equemene
409 231 equemene
  elapsed=(MYFLOAT)((tv2.tv_sec-tv1.tv_sec) * 1000000L +
410 231 equemene
                   (tv2.tv_usec-tv1.tv_usec))/1000000;
411 231 equemene
  cputime=(MYFLOAT)((mtv2-mtv1)/1000.);
412 231 equemene
  epoch=(MYFLOAT)(epoch2-epoch1);
413 214 equemene
414 304 equemene
  fmx=fp[0];
415 304 equemene
  zmx=zp[0];
416 197 equemene
417 197 equemene
  for (i=0;i<dim;i++) for (j=0;j<dim;j++)
418 197 equemene
    {
419 304 equemene
      if (fmx<fp[i+dim*j])
420 197 equemene
        {
421 214 equemene
          fimx=i;
422 214 equemene
          fjmx=j;
423 304 equemene
          fmx=fp[i+dim*j];
424 197 equemene
        }
425 197 equemene
426 304 equemene
      if (zmx<zp[i+dim*j])
427 197 equemene
        {
428 214 equemene
          zimx=i;
429 214 equemene
          zjmx=j;
430 304 equemene
          zmx=zp[i+dim*j];
431 197 equemene
        }
432 197 equemene
    }
433 197 equemene
434 214 equemene
  printf("\nElapsed Time : %lf",(double)elapsed);
435 231 equemene
  printf("\nCPU Time : %lf",(double)cputime);
436 231 equemene
  printf("\nEpoch Time : %lf",(double)epoch);
437 292 equemene
  printf("\nZ max @(%.6f,%.6f) : %.6f",
438 292 equemene
         (float)zimx/(float)dim-0.5,0.5-(float)zjmx/(float)dim,zmx);
439 292 equemene
  printf("\nFlux max @(%.6f,%.6f) : %.6f\n\n",
440 292 equemene
         (float)fimx/(float)dim-0.5,0.5-(float)fjmx/(float)dim,fmx);
441 292 equemene
442 231 equemene
  // If input parameters set without output files precised
443 231 equemene
  if (argc!=7) {
444 231 equemene
    for (int i=0;i<dim;i++)
445 231 equemene
      for (int j=0;j<dim;j++)
446 197 equemene
        {
447 304 equemene
          zcl=(int)(255/zmx*zp[i+dim*(dim-1-j)]);
448 304 equemene
          fcl=(int)(255/fmx*fp[i+dim*(dim-1-j)]);
449 197 equemene
450 231 equemene
          if (strcmp(argv[6],"NEGATIVE")==0)
451 197 equemene
            {
452 231 equemene
              if (zcl>255)
453 231 equemene
                {
454 304 equemene
                  izp[i+dim*j]=0;
455 231 equemene
                }
456 231 equemene
              else
457 231 equemene
                {
458 304 equemene
                  izp[i+dim*j]=255-zcl;
459 231 equemene
                }
460 231 equemene
461 231 equemene
              if (fcl>255)
462 231 equemene
                {
463 304 equemene
                  ifp[i+dim*j]=0;
464 231 equemene
                }
465 231 equemene
              else
466 231 equemene
                {
467 304 equemene
                  ifp[i+dim*j]=255-fcl;
468 231 equemene
                }
469 231 equemene
470 197 equemene
            }
471 197 equemene
          else
472 197 equemene
            {
473 231 equemene
              if (zcl>255)
474 231 equemene
                {
475 304 equemene
                  izp[i+dim*j]=255;
476 231 equemene
                }
477 231 equemene
              else
478 231 equemene
                {
479 304 equemene
                  izp[i+dim*j]=zcl;
480 231 equemene
                }
481 231 equemene
482 231 equemene
              if (fcl>255)
483 231 equemene
                {
484 304 equemene
                  ifp[i+dim*j]=255;
485 231 equemene
                }
486 231 equemene
              else
487 231 equemene
                {
488 304 equemene
                  ifp[i+dim*j]=fcl;
489 231 equemene
                }
490 231 equemene
491 197 equemene
            }
492 197 equemene
493 197 equemene
        }
494 231 equemene
495 231 equemene
    if (argc==9)
496 231 equemene
      {
497 231 equemene
        sauvegarde_pgm(argv[7],ifp,dim);
498 231 equemene
        sauvegarde_pgm(argv[8],izp,dim);
499 231 equemene
      }
500 231 equemene
    else
501 231 equemene
      {
502 231 equemene
        sauvegarde_pgm("z.pgm",izp,dim);
503 231 equemene
        sauvegarde_pgm("flux.pgm",ifp,dim);
504 231 equemene
      }
505 231 equemene
  }
506 197 equemene
  else
507 197 equemene
    {
508 231 equemene
      printf("No output file precised, useful for benchmarks...\n\n");
509 197 equemene
    }
510 231 equemene
511 197 equemene
  free(zp);
512 197 equemene
  free(fp);
513 197 equemene
514 197 equemene
  free(izp);
515 197 equemene
  free(ifp);
516 197 equemene
517 197 equemene
}
518 197 equemene