Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F99133568
read_lenstable.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 20, 23:17
Size
2 KB
Mime Type
text/x-c
Expires
Wed, Jan 22, 23:17 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23699688
Attached To
R1448 Lenstool-HPC
read_lenstable.c
View Options
/*this function will read a binary file containing gnfw slope (alpha),
x (r/rsc), kappa and dpl. These values will have to be rescaled
before being used by lenstool. The function will return the number
of complete entries made*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include "wcs.h"
#include <dimension.h>
#include <structure.h>
extern
lensdata
*
lens_table
;
void
read_lenstable
()
{
long
int
i
,
tot_count
;
char
infile
[
200
];
char
*
dir
;
long
int
alphasteps
,
xsteps
;
lensdata
array_tmp
[
2
];
// Read the first 2 rows of lenstable[]
FILE
*
inf
;
// BUG: The lenstool.tab datafile only needs to exist in ONE place -
// preferably the table_src directory. lenstool needs to use environment
// variables for this!! Suggest:
dir
=
getenv
(
"LENSTOOL_DIR"
);
if
(
dir
==
NULL
)
{
fprintf
(
stderr
,
"ERROR: LENSTOOL_DIR environment variable is not defined. Unable to find lenstool.tab file
\n
"
);
exit
(
-
1
);
}
strcpy
(
infile
,
dir
);
strcat
(
infile
,
"/table_src/lenstool.tab"
);
inf
=
fopen
(
infile
,
"rb+"
);
if
(
inf
==
NULL
)
{
fprintf
(
stderr
,
"ERROR: Unable to find %s
\n
"
,
infile
);
exit
(
-
1
);
}
fprintf
(
stderr
,
"READ: lens_table binary file into array..."
);
//read in the first two rows (0:alpha,1:x) to find out how many more lines to read
fread
(
&
array_tmp
[
0
],
sizeof
(
lensdata
),
1
,
inf
);
alphasteps
=
(
long
int
)
array_tmp
[
0
].
x_now
;
fread
(
&
array_tmp
[
1
],
sizeof
(
lensdata
),
1
,
inf
);
xsteps
=
(
long
int
)
array_tmp
[
1
].
x_now
;
tot_count
=
xsteps
*
alphasteps
+
2
;
if
(
tot_count
>
ARRAY_SIZE
)
{
fprintf
(
stderr
,
"
\n
READ ERROR: lens_table, Need to increase output array size!!!
\n
"
);
exit
(
-
1
);
}
// Allocate lens_table
lens_table
=
(
lensdata
*
)
malloc
(
(
unsigned
int
)
tot_count
*
sizeof
(
lensdata
)
);
// Fill the first 2 rows of lens_table with array_tmp
memcpy
(
&
lens_table
[
0
],
&
array_tmp
[
0
],
sizeof
(
lensdata
)
);
memcpy
(
&
lens_table
[
1
],
&
array_tmp
[
1
],
sizeof
(
lensdata
)
);
for
(
i
=
2
;
i
<
tot_count
;
i
++
)
fread
(
&
lens_table
[
i
],
sizeof
(
lensdata
),
1
,
inf
);
fprintf
(
stderr
,
"done
\n
"
);
fprintf
(
stderr
,
"INFO: NFWg limits (alpha[%lf,%lf], r/rs[%lf,%lf])
\n
"
,
lens_table
[
2
].
alpha_now
,
lens_table
[
tot_count
-
1
].
alpha_now
,
lens_table
[
2
].
x_now
,
lens_table
[
tot_count
-
1
].
x_now
);
fclose
(
inf
);
}
Event Timeline
Log In to Comment