Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98839399
e_nfwtri.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, 20:01
Size
3 KB
Mime Type
text/x-c
Expires
Sat, Jan 18, 20:01 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23607068
Attached To
R1448 Lenstool-HPC
e_nfwtri.c
View Options
#include<stdio.h>
#include<math.h>
#include<fonction.h>
#include<constant.h>
#include<dimension.h>
#include<structure.h>
/****************************************************************/
/* nom: e_nfwtri */
/* auteur: TV & EJ */
/* date: 2012 */
/* place: */
/****************************************************************
*
* Adding triaxiality in the NFW profile
* following Oguri, Lee & Suto 2003 (OLS03)
*
*/
/* --------------------------------------------------------------*
* Return Eq. 28, A value (OLS03)
*/
double AA_tri(const struct pot *ilens)
{
double AA_tri1,AA_tri2,AA_tri3,AA_tri4, AA_tri;
AA_tri1 = cos(ilens->theta)*cos(ilens->theta);
AA_tri2 = (1./ilens->epot)*(1./ilens->epot)*sin(ilens->phi)*sin(ilens->phi);
AA_tri3 = (1./ilens->emass)*(1./ilens->emass)*cos(ilens->phi)*cos(ilens->phi);
AA_tri4 = (1./ilens->epot)*(1./ilens->epot)*(1./ilens->emass)*(1./ilens->emass)*sin(ilens->theta)*sin(ilens->theta);
AA_tri = AA_tri1*(AA_tri2+AA_tri3) + AA_tri4;
return (AA_tri);
}
/* --------------------------------------------------------------*
* Return Eq. 29, B value (OLS03)
*/
double BB_tri(const struct pot *ilens)
{
double BB_tri1,BB_tri2,BB_tri3, BB_tri;
BB_tri1 = cos(ilens->theta)*sin(2.*(ilens->phi));
BB_tri2 = (1./ilens->epot)*(1./ilens->epot);
BB_tri3 = (1./ilens->emass)*(1./ilens->emass);
BB_tri = BB_tri1*(BB_tri2 - BB_tri3);
return (BB_tri);
}
/* --------------------------------------------------------------*
* Return Eq. 30, C value (OLS03)
*/
double CC_tri(const struct pot *ilens)
{
double CC_tri1,CC_tri2, CC_tri;
CC_tri1 = (1./ilens->emass)*(1./ilens->emass)*sin(ilens->phi)*sin(ilens->phi);
CC_tri2 = (1./ilens->epot)*(1./ilens->epot)*cos(ilens->phi)*cos(ilens->phi);
CC_tri = CC_tri1 + CC_tri2;
return (CC_tri);
}
/* --------------------------------------------------------------*
* Return Eq. 31, Psi value (OLS03)
*/
double Psi_tri(const struct pot *ilens)
{
double Psi_tri;
Psi_tri = (1./2.)*atan( BB_tri(ilens)/( AA_tri(ilens)-CC_tri(ilens) ) );
return (Psi_tri);
}
/* --------------------------------------------------------------*
* Return the ellipticity of the projected ellipsoids, i.e. the ellipticities of the ellipses
*/
double elli_tri(const struct pot *ilens)
{
double elli_tri1,elli_tri2, elli_tri;
elli_tri1 = 1./( AA_tri(ilens)+CC_tri(ilens)-sqrt((AA_tri(ilens)-CC_tri(ilens))*(AA_tri(ilens)-CC_tri(ilens))+BB_tri(ilens)*BB_tri(ilens)) );
elli_tri2 = 1./( AA_tri(ilens)+CC_tri(ilens)+sqrt((AA_tri(ilens)-CC_tri(ilens))*(AA_tri(ilens)-CC_tri(ilens))+BB_tri(ilens)*BB_tri(ilens)) );
elli_tri = (elli_tri1-elli_tri2)/(elli_tri1+elli_tri2);
return (elli_tri);
}
/* --------------------------------------------------------------*
* Return the 2D concentration, acording to Jing & Suto 2002
*/
void e_nfw_c3D2c2D(double c3D,double *c2D)
{
*c2D = c3D/0.45;
}
Event Timeline
Log In to Comment