Statistiques
| Révision :

root / TrouNoir / trou_noir_OpenMP.c @ 301

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

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

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

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

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

13 230 equemene
        Remerciements a :
14 230 equemene

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

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

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