Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F97135388
e_gcpx.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 2, 20:04
Size
3 KB
Mime Type
text/x-c
Expires
Sat, Jan 4, 20:04 (2 d)
Engine
blob
Format
Raw Data
Handle
23333143
Attached To
R1448 Lenstool-HPC
e_gcpx.c
View Options
#include<stdio.h>
#include<math.h>
#include<fonction.h>
#include<constant.h>
#include<dimension.h>
#include<structure.h>
/****************************************************************/
/* nom: e_grad */
/* auteur: Jean-Paul Kneib */
/* date: 10/02/92 */
/* place: Toulouse */
/****************************************************************/
/*
* SIEMD KK
* Global variables used :
* - none
*/
complex
csiemd
(
double
x
,
double
y
,
double
eps
,
double
b0
)
{
double
sqe
,
ce0
,
ce1
,
ce2
;
double
r
;
complex
zres
;
r
=
sqrt
(
x
*
x
+
y
*
y
);
sqe
=
sqrt
(
eps
);
ce0
=
b0
*
(
1
-
eps
*
eps
)
/
2.
/
sqe
;
ce1
=
2.
*
sqe
/
(
1.
+
eps
);
ce2
=
2.
*
sqe
/
(
1.
-
eps
);
zres
.
re
=
ce0
*
asin
(
ce1
*
x
/
r
);
zres
.
im
=
ce0
*
asinh
(
ce2
*
y
/
r
);
return
(
zres
);
}
/*
* I*w,v=0.5 Kassiola & Kovner, 1993 PIEMD, paragraph 4.1
* Same as ci05() but with circular clumps. Much faster!!
*
*
* Global variables used :
* - none
*/
/*
* I*w,v=0.5 Kassiola & Kovner, 1993 PIEMD, paragraph 4.1
*
* Global variables used :
* - none
*/
complex
ci05
(
double
x
,
double
y
,
double
eps
,
double
rc
)
{
double
sqe
,
cx1
,
cxro
,
cyro
,
rem2
;
complex
zci
,
znum
,
zden
,
zis
,
zres
;
double
norm
;
sqe
=
sqrt
(
eps
);
cx1
=
(
1.
-
eps
)
/
(
1.
+
eps
);
cxro
=
(
1.
+
eps
)
*
(
1.
+
eps
);
cyro
=
(
1.
-
eps
)
*
(
1.
-
eps
);
rem2
=
x
*
x
/
cxro
+
y
*
y
/
cyro
;
/*zci=cpx(0.,-0.5*(1.-eps*eps)/sqe);
znum=cpx(cx1*x,(2.*sqe*sqrt(rc*rc+rem2)-y/cx1));
zden=cpx(x,(2.*rc*sqe-y));
zis=pcpx(zci,lncpx(dcpx(znum,zden)));
zres=pcpxflt(zis,b0);*/
// --> optimized code
zci
.
re
=
0
;
zci
.
im
=
-
0.5
*
(
1.
-
eps
*
eps
)
/
sqe
;
znum
.
re
=
cx1
*
x
;
znum
.
im
=
2.
*
sqe
*
sqrt
(
rc
*
rc
+
rem2
)
-
y
/
cx1
;
zden
.
re
=
x
;
zden
.
im
=
2.
*
rc
*
sqe
-
y
;
norm
=
zden
.
re
*
zden
.
re
+
zden
.
im
*
zden
.
im
;
// zis = znum/zden
zis
.
re
=
(
znum
.
re
*
zden
.
re
+
znum
.
im
*
zden
.
im
)
/
norm
;
zis
.
im
=
(
znum
.
im
*
zden
.
re
-
znum
.
re
*
zden
.
im
)
/
norm
;
norm
=
zis
.
re
;
zis
.
re
=
log
(
sqrt
(
norm
*
norm
+
zis
.
im
*
zis
.
im
));
// ln(zis) = ln(|zis|)+i.Arg(zis)
zis
.
im
=
atan2
(
zis
.
im
,
norm
);
// norm = zis.re;
zres
.
re
=
zci
.
re
*
zis
.
re
-
zci
.
im
*
zis
.
im
;
// Re( zci*ln(zis) )
zres
.
im
=
zci
.
im
*
zis
.
re
+
zis
.
im
*
zci
.
re
;
// Im( zci*ln(zis) )
//zres.re = zis.re*b0;
//zres.im = zis.im*b0;
return
(
zres
);
}
/*
* I1.5 KK
* Global variables used :
* - none
*/
complex
ci15
(
double
x
,
double
y
,
double
eps
,
double
rc
,
double
b0
)
{
double
sqe
,
cx1
,
cxro
,
cyro
,
wrem
;
complex
zaa
,
zbb
,
ztot
,
zres
;
cx1
=
(
1.
-
eps
)
/
(
1.
+
eps
);
cxro
=
(
1.
+
eps
)
*
(
1.
+
eps
);
cyro
=
(
1.
-
eps
)
*
(
1.
-
eps
);
sqe
=
sqrt
(
eps
);
wrem
=
sqrt
(
rc
*
rc
+
x
*
x
/
cxro
+
y
*
y
/
cyro
);
zaa
=
cpx
(
x
,
-
y
+
2
*
rc
*
sqe
);
zbb
=
cpx
(
cx1
*
x
,
-
y
/
cx1
+
2
*
wrem
*
sqe
);
ztot
=
scpx
(
icpx
(
zaa
),
pcpxflt
(
icpx
(
zbb
),
rc
/
wrem
));
zres
=
pcpxflt
(
ztot
,
b0
*
rc
*
(
1.
-
eps
*
eps
));
return
(
zres
);
}
/*
* I1.0 KK -we actually return I_1/rc
* Global variables used :
* - none
*/
complex
ci10
(
double
x
,
double
y
,
double
eps
,
double
rc
,
double
b0
)
{
double
cx1
,
cxro
,
cyro
,
wrem
;
complex
sqzs
,
sqz
,
zbar
,
zaa
,
zbb
,
ztot
,
zres
;
cx1
=
(
1.
-
eps
)
/
(
1.
+
eps
);
cxro
=
(
1.
+
eps
)
*
(
1.
+
eps
);
cyro
=
(
1.
-
eps
)
*
(
1.
-
eps
);
wrem
=
sqrt
(
rc
*
rc
+
x
*
x
/
cxro
+
y
*
y
/
cyro
);
zbar
=
cpx
(
x
,
-
y
);
sqz
=
sqrtcpx
(
acpxflt
(
pcpx
(
zbar
,
zbar
),
(
4.
*
eps
*
rc
*
rc
)));
sqzs
=
pcpxflt
(
sqz
,
sgn_darg
(
sqz
,
zbar
));
zaa
=
acpx
(
zbar
,
sqzs
);
zbb
=
acpx
(
cpx
(
cx1
*
x
,
-
y
/
cx1
),
sqzs
);
ztot
=
dcpx
(
lncpx
(
pcpxflt
(
dcpx
(
zaa
,
zbb
),
wrem
/
rc
)),
sqzs
);
zres
=
pcpxflt
(
ztot
,
b0
*
(
1.
-
eps
*
eps
));
return
(
zres
);
}
Event Timeline
Log In to Comment