Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F97815847
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 6, 15:00
Size
2 KB
Mime Type
text/x-c
Expires
Wed, Jan 8, 15:00 (2 d)
Engine
blob
Format
Raw Data
Handle
23371861
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, "\nREAD 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