Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98824205
r_observ.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
Thu, Jan 16, 17:05
Size
3 KB
Mime Type
text/x-c
Expires
Sat, Jan 18, 17:05 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23647754
Attached To
R1448 Lenstool-HPC
r_observ.c
View Options
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<fonction.h>
#include<constant.h>
#include<dimension.h>
#include<structure.h>
#include<lt.h>
/****************************************************************/
/* Program : r_observ */
/* Version : 16 septembre 1992 */
/* Location : Obs. Toulouse */
/* Auteur : Henri */
/****************************************************************/
void
r_observ
(
FILE
*
IN
,
FILE
*
OUT
)
{
extern
struct
g_mode
M
;
extern
struct
g_observ
O
;
char
second
[
20
],
third
[
FILENAME_SIZE
+
10
];
double
disp
;
disp
=
0.
;
O
.
gain
=
0.
;
fmot
(
IN
,
second
);
while
(
strcmp
(
second
,
"end"
))
{
flire
(
IN
,
third
);
CHECK_THIRD
(
FILENAME_SIZE
+
10
)
if
(
!
strcmp
(
second
,
"bruit"
))
{
sscanf
(
third
,
"%d"
,
&
O
.
bruit
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%d
\n
"
,
second
,
O
.
bruit
);
}
else
if
((
!
strcmp
(
second
,
"sky"
))
||
(
!
strcmp
(
second
,
"SKY"
)))
{
sscanf
(
third
,
"%lf"
,
&
O
.
SKY
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%lf
\n
"
,
second
,
O
.
SKY
);
}
else
if
(
!
strcmp
(
second
,
"idum"
))
{
sscanf
(
third
,
"%d"
,
&
O
.
idum
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%d
\n
"
,
second
,
O
.
idum
);
}
else
if
(
!
strcmp
(
second
,
"dispersion"
))
{
sscanf
(
third
,
"%lf"
,
&
disp
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%lf
\n
"
,
second
,
disp
);
}
else
if
(
!
strcmp
(
second
,
"gain"
))
{
sscanf
(
third
,
"%lf"
,
&
O
.
gain
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%lf
\n
"
,
second
,
O
.
gain
);
}
else
if
(
!
strcmp
(
second
,
"prec"
))
{
sscanf
(
third
,
"%lf"
,
&
O
.
prec
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%lf
\n
"
,
second
,
O
.
prec
);
}
else
if
(
!
strcmp
(
second
,
"binning"
))
{
sscanf
(
third
,
"%d%d"
,
&
O
.
setbin
,
&
O
.
bin
);
fprintf
(
OUT
,
"
\t
%s
\t\t
%d %d
\n
"
,
second
,
O
.
setbin
,
O
.
bin
);
}
else
if
(
!
strcmp
(
second
,
"seeing"
))
{
sscanf
(
third
,
"%d%lf"
,
&
O
.
setseeing
,
&
O
.
seeing
);
if
(
O
.
setseeing
)
{
O
.
setseeing
=
1
;}
O
.
r0st
=
O
.
seeing
/
sqrt
(
log
(
2.
));
O
.
r0st
=
O
.
r0st
*
O
.
r0st
;
fprintf
(
OUT
,
"
\t
%s
\t\t
%d %lf
\n
"
,
second
,
O
.
setseeing
,
O
.
seeing
);
}
else
if
(
!
strcmp
(
second
,
"seeing_e"
))
{
sscanf
(
third
,
"%d%lf%lf%lf"
,
&
O
.
setseeing
,
&
O
.
seeing_a
,
&
O
.
seeing_b
,
&
O
.
seeing_angle
);
if
(
O
.
setseeing
)
{
O
.
setseeing
=
2
;}
O
.
r0st_a
=
O
.
seeing_a
/
sqrt
(
log
(
2.
));
O
.
r0st_b
=
O
.
seeing_b
/
sqrt
(
log
(
2.
));
O
.
r0st_a
=
O
.
r0st_a
*
O
.
r0st_a
;
O
.
r0st_b
=
O
.
r0st_b
*
O
.
r0st_b
;
fprintf
(
OUT
,
"
\t
%s
\t\t
%d %lf %lf %lf
\n
"
,
second
,
O
.
setseeing
,
O
.
seeing_a
,
O
.
seeing_b
,
O
.
seeing_angle
);
}
else
if
(
!
strcmp
(
second
,
"psf"
))
{
sscanf
(
third
,
"%d%s"
,
&
O
.
setseeing
,
O
.
psffile
);
if
(
O
.
setseeing
)
{
O
.
setseeing
=
3
;}
}
// Read the next line
fmot
(
IN
,
second
);
}
fprintf
(
OUT
,
"
\t
%s
\n
"
,
second
);
if
((
O
.
bruit
!=
0
)
&&
(
O
.
gain
==
0.
))
{
if
(
disp
!=
0
)
O
.
gain
=
O
.
SKY
/
disp
/
disp
;
else
{
NPRINTF
(
stderr
,
"WARNING: ain or dispersion not defined, no noise will be added
\n
"
);
O
.
bruit
=
0
;
}
}
}
Event Timeline
Log In to Comment