Statistiques
| Révision :

root / TrouNoir / trou_noir_OpenACC.c @ 290

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

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

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

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

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

13 290 equemene
        Remerciements a :
14 290 equemene

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

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

23 290 equemene
        Version FP32 : gcc -fopenmp -O3 -ffast-math -DFP32 -o trou_noir_OMP_FP32 trou_noir_OpenMP.c -lm -lgomp
24 290 equemene
        Version FP64 : gcc -fopenmp -O3 -ffast-math -FP64 -o trou_noir_OMP_FP64 trou_noir_OpenMP.c -lm -lgomp
25 290 equemene

26 290 equemene
        Version FP32 : gcc -O3 -fopenacc  -ffast-math -DFP32 -foffload=nvptx-none -foffload="-O3 -misa=sm_35 -lm" -o trou_noir_openacc_FP32 trou_noir_OpenACC.c -lm
27 290 equemene
        Version FP64 : gcc -O3 -fopenacc  -ffast-math -DFP64 -foffload=nvptx-none -foffload="-O3 -misa=sm_35 -lm" -o trou_noir_openacc_FP64 trou_noir_OpenACC.c -lm
28 290 equemene

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