Page MenuHomec4science

o_runz2.c
No OneTemporary

File Metadata

Created
Thu, Jan 16, 20:34

o_runz2.c

#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<fonction.h>
#include<constant.h>
#include<dimension.h>
#include<structure.h>
#include "lt.h"
/****************************************************************/
/* nom: o_runz2 */
/* auteur: Ghislain Golse */
/* date: 09/99 */
/* place: Toulouse */
/****************************************************************/
int optim_z;
void o_runz2()
{
extern struct g_mode M;
extern struct g_image I;
extern struct g_grille G;
extern struct ipot ip;
extern struct pot lens[], lmin[], lmax[], prec[];
extern struct z_lim zlim[];
extern struct galaxie multi[][NIMAX];
extern int block[][NPAMAX];
extern double chip, chis, chil, chia; //chix,chiy,
extern double **map_p;
register int i, j, k;
int ils = -1, ipx = -1, iz = -1, n1, stop = 0, ic = 0;
int sblock[NLMAX][NPAMAX];
FILE *OUT, *MAP;
double chi0, z0;
double savchi, minchi;
double pmin, pmax, dp;
struct pot best[NLMAX], save[NLMAX], slmin[NLMAX], slmax[NLMAX], sprec[NLMAX];
struct z_lim szlim[NFMAX];
double bestz[NIMAX], z_save[NIMAX];
double **mbest_p, **smap_p;
OUT = fopen("map.res", "w");
MAP = fopen("map.iso", "w");
/* z0 fixe pour trouver le gradient*/
optim_z = 0;
/* for(i=0;i<I.n_mult;i++)
for(j=0;j<I.mult[i];j++)
NPRINTF(stderr,"multi[%d][%d]=(%.3lf,%.3lf)\n",i,j,multi[i][j].C.x,multi[i][j].C.y); */
/* sauvegarde des parametres des lentilles */
if (lens[0].type != 10)
for (j = 0; j < G.no_lens; j++)
{
best[j] = lens[j];
save[j] = lens[j];
slmin[j] = lmin[j];
slmax[j] = lmax[j];
sprec[j] = prec[j];
for (k = 0; k < ip.pmax; k++)
sblock[j][k] = block[j][k];
}
else
{
mbest_p = (double **) alloc_square_double (G.nx, G.ny);
mbest_p = map_p;
smap_p = (double **) alloc_square_double (G.nx, G.ny);
smap_p = map_p;
}
for (j = 0; j < I.nzlim; j++)
szlim[j] = zlim[j];
if (ip.lens[0] >= 0)
{
ils = ip.lens[0];
ipx = ip.para[0];
n1 = abs(block[ils][ipx]);
pmin = o_get_lmin(ils, ipx);
pmax = o_get_lmax(ils, ipx);
}
else if (ip.zlim[0] >= 0)
{
iz = ip.zlim[0];
NPRINTF(stderr, "ip.zlim[0]=%d \n", iz);
n1 = abs(zlim[iz].bk);
pmin = zlim[iz].min;
pmax = zlim[iz].max;
}
else
{
fprintf(stderr, "ERROR: in o_runz\n");
exit(-1);
};
dp = (pmax - pmin) / ((double)(n1 - 1));
savchi = minchi = o_chi();
NPRINTF(stderr, "minchi %lf \n", minchi);
NPRINTF(stderr, "boucle %d %lf %lf %lf \n", n1, pmin, pmax, dp);
z0 = pmin;
if (ipx >= 0)
o_set_lens(ils, ipx, z0);
else
multi[iz][0].dr = dratio(lens[0].z, z0);
chi0 = o_prep();
NPRINTF(stderr, "\n\n%d %d chi0=%.3lf par: z0=%.3lf\n", j, ic = 0, chi0, z0);
stop = 0;
/******* boucle en z ****************/
optim_z = 1;
for (i = 0; i < I.n_mult; i++)
for (j = 0; j < I.mult[i]; j++)
NPRINTF(stderr, "GradPot[%d][%d]=(%.3lf,%.3lf)\n", i, j, multi[i][j].Grad.x, multi[i][j].Grad.y);
for (j = 0; j < n1; j++)
{
z0 = pmin + ((double) j) * dp;
if (ipx >= 0)
{
/* NPRINTF(stderr,"ipx>=0"); */
o_set_lens(ils, ipx, z0);
}
else
{
multi[iz][0].dr = dratio(lens[0].z, z0);
/* NPRINTF(stderr,"dratio"); */
}
chi0 = o_chi();
NPRINTF(stderr, "%d/z0=%.3lf chi0=%.3lf p:%.3lf s:%.3lf l:%.3lf a:%.3lf\n",
j, z0, chi0, chip, chis, chil, chia);
if (chi0 < minchi)
{
minchi = chi0;
if (lens[0].type != 10)
for (i = 0; i < G.no_lens; i++)
best[i] = lens[i];
else
mbest_p = map_p;
for (i = 0; i < I.nzlim; i++)
{
bestz[i] = multi[i][0].dr;
z_save[i] = z0;
}
};
fprintf(MAP, "%lf %lf\n", z0, chi0);
o_print(OUT, chi0);
if (lens[0].type != 10)
for (i = 0; i < G.no_lens; i++)
{
if (savchi < chi0)
lens[i] = save[i];
lmin[i] = slmin[i];
lmax[i] = slmax[i];
prec[i] = sprec[i];
for (k = 0; k < ip.pmax; k++)
block[i][k] = sblock[i][k];
}
else
map_p = smap_p;
for (i = 0; i < I.nzlim; i++)
zlim[i] = szlim[i];
}
fclose(MAP);
fclose(OUT);
if (minchi < savchi)
{
if (lens[0].type != 10)
for (i = 0; i < G.no_lens; i++)
lens[i] = best[i];
else
map_p = mbest_p;
for (i = 0; i < I.nzlim; i++)
{
multi[i][0].dr = bestz[i];
multi[i][0].z = z_save[i];
}
};
/*
* reset lens parameters
*/
//o_chires();
//set_res_par();
/*
* print results
*/
//o_print_res(minchi,0.);
/*
* free maps
*/
free_square_double((double **) mbest_p, G.nx);
free_square_double((double **) smap_p, G.nx);
}

Event Timeline