Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F99069314
g_shearf.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
Sun, Jan 19, 10:57
Size
4 KB
Mime Type
text/x-c
Expires
Tue, Jan 21, 10:57 (2 d)
Engine
blob
Format
Raw Data
Handle
23700095
Attached To
R1448 Lenstool-HPC
g_shearf.c
View Options
#include<stdio.h>
#include<math.h>
#include <stdlib.h>
#include "fonction.h"
#include "constant.h"
#include "dimension.h"
#include "structure.h"
/****************************************************************/
/* nom: g_shearf */
/* auteur: Jean-Paul Kneib */
/* date: 10/02/92 */
/* place: Toulouse */
/* Modified : */
/* EJ (02/09/05)--Print absolute coordinates */
/****************************************************************/
void
g_shearf
(
int
ishearf
,
double
z
,
char
*
file
,
int
nshearf
)
{
const
extern
struct
g_mode
M
;
const
extern
struct
g_frame
F
;
const
extern
struct
pot
lens
[];
struct
point
pi
;
struct
pointell
**
shear
;
struct
pointell
*
s
;
register
int
i
,
j
;
double
e
,
q
;
double
dl0s
,
dos
,
dlsds
;
double
Cx
,
Cy
;
FILE
*
OUT
;
// Create the shear array
shear
=
(
struct
pointell
**
)(
malloc
((
unsigned
)
nshearf
*
sizeof
(
struct
pointell
*
)));
for
(
i
=
0
;
i
<
nshearf
;
i
++
)
shear
[
i
]
=
(
struct
pointell
*
)(
malloc
((
unsigned
)
nshearf
*
sizeof
(
struct
pointell
)));
if
(
ishearf
==
1
)
{
NPRINTF
(
stderr
,
"COMP: shear_field (eps) in the Image Plane for z_s=%.3lf=>%s
\n
"
,
z
,
file
);
}
else
if
(
ishearf
==
2
)
{
NPRINTF
(
stderr
,
"COMP: shear_field (ori) in the Image Plane for z_s=%.3lf=>%s
\n
"
,
z
,
file
);
}
else
if
(
ishearf
==
3
)
{
NPRINTF
(
stderr
,
"COMP: shear_field (tau) in the Image Plane for z_s=%.3lf=>%s
\n
"
,
z
,
file
);
}
else
if
(
ishearf
==
4
)
{
NPRINTF
(
stderr
,
"COMP: shear_field (ellipse) in the Image Plane for z_s=%.3lf=>%s
\n
"
,
z
,
file
);
}
dl0s
=
distcosmo2
(
lens
[
0
].
z
,
z
);
dos
=
distcosmo1
(
z
);
dlsds
=
dl0s
/
dos
;
for
(
j
=
0
;
j
<
nshearf
;
j
++
)
{
pi
.
y
=
j
*
(
F
.
ymax
-
F
.
ymin
)
/
(
nshearf
-
1
)
+
F
.
ymin
;
for
(
i
=
0
;
i
<
nshearf
;
i
++
)
{
pi
.
x
=
i
*
(
F
.
xmax
-
F
.
xmin
)
/
(
nshearf
-
1
)
+
F
.
xmin
;
shear
[
i
][
j
].
E
=
e_unmag
(
&
pi
,
dl0s
,
dos
,
z
);
shear
[
i
][
j
].
C
=
pi
;
}
}
// Write file on disk
OUT
=
fopen
(
file
,
"w"
);
if
(
M
.
iref
==
3
)
fprintf
(
OUT
,
"#REFERENCE 3 %lf %lf
\n
"
,
M
.
ref_ra
,
M
.
ref_dec
);
else
fprintf
(
OUT
,
"#REFERENCE 0
\n
"
);
for
(
j
=
0
;
j
<
nshearf
;
j
++
)
for
(
i
=
0
;
i
<
nshearf
;
i
++
)
{
s
=
&
shear
[
i
][
j
];
q
=
s
->
E
.
a
/
s
->
E
.
b
;
e
=
(
q
*
q
-
1.
)
/
(
q
*
q
+
1.
);
Cy
=
s
->
C
.
y
;
Cx
=
s
->
C
.
x
;
if
(
ishearf
==
1
)
{
if
(
e
>
0.
)
fprintf
(
OUT
,
"%d %.6lf %.6lf %.4lf %.4lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
e
,
0.
,
RTD
*
s
->
E
.
theta
,
0.
,
0.
);
else
fprintf
(
OUT
,
"%d %.6lf %.6lf %.4lf %.4lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
0.
,
-
e
,
RTD
*
s
->
E
.
theta
,
0.
,
0.
);
}
else
if
(
ishearf
==
2
)
{
if
(
e
>
0.
)
fprintf
(
OUT
,
"%d %.6lf %.6lf %.4lf %.4lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
1.
,
0.
,
RTD
*
s
->
E
.
theta
,
0.
,
0.
);
else
fprintf
(
OUT
,
"%d %.6lf %.6lf %.4lf %.4lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
0.
,
1.
,
RTD
*
s
->
E
.
theta
,
0.
,
0.
);
}
else
if
(
ishearf
==
3
)
{
e
=
(
q
*
q
-
1.
)
/
2
/
q
;
if
(
e
>
0.
)
fprintf
(
OUT
,
"%d %.6lf %.6lf %.4lf %.4lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
e
,
0.
,
RTD
*
s
->
E
.
theta
,
0.
,
0.
);
else
fprintf
(
OUT
,
"%d %.6lf %.6lf %.4lf %.4lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
0.
,
-
e
,
RTD
*
s
->
E
.
theta
,
0.
,
0.
);
}
else
if
(
ishearf
==
4
)
{
// +90 because the shear angle is radial and we want ellipses
// tangeantially oriented
fprintf
(
OUT
,
"%d %.6lf %.6lf %.5lf %.5lf %7.2lf %.1lf %.1lf
\n
"
,
i
,
Cx
,
Cy
,
s
->
E
.
a
,
s
->
E
.
b
,
RTD
*
s
->
E
.
theta
+
90
,
0.
,
0.
);
}
};
fclose
(
OUT
);
}
Event Timeline
Log In to Comment