Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F97648038
o_runz.c
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Mon, Jan 6, 01:26
Size
6 KB
Mime Type
text/x-c
Expires
Wed, Jan 8, 01:26 (10 h, 43 m)
Engine
blob
Format
Raw Data
Handle
23371841
Attached To
R1448 Lenstool-HPC
o_runz.c
View Options
#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_runz */
/* auteur: Ghislain Golse */
/* date: 09/99 */
/* place: Toulouse */
/****************************************************************/
int
optim_z
;
void
o_runz
()
{
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"
);
/* Optimisation avec z0 fixe */
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
+
pmax
)
/
2
;
/* 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
;
do
{
chi0
=
o_step
(
chi0
);
if
(
chi0
<
0.
)
{
chi0
=
-
chi0
;
stop
=
1
;
}
ic
++
;
FPRINTF
(
stderr
,
"%d/%d %.3lf p:%.3lf s:%.3lf l:%.3lf a:%.3lf
\r
"
,
ic
,
M
.
itmax
,
chi0
,
chip
,
chis
,
chil
,
chia
);
}
while
((
chi0
>
M
.
minchi0
)
&&
(
stop
!=
1
)
&&
(
ic
<
M
.
itmax
));
NPRINTF
(
stderr
,
"%d/%d %.3lf p:%.3lf s:%.3lf l:%.3lf a:%.3lf
\n
"
,
ic
,
M
.
itmax
,
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
];
/******* boucle en z ****************/
optim_z
=
1
;
fclose
(
MAP
);
fclose
(
OUT
);
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
];
}
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
Log In to Comment