diff --git a/gstlal-ugly/examples/configurations/PE/interp/cheby_interp.c b/gstlal-ugly/examples/configurations/PE/interp/cheby_interp.c index 4afcb0ceacd4b18ba13e4f44f0386c98a3ac107d..2a457f88b59a59c859067937b0cc9333b26fdcac 100644 --- a/gstlal-ugly/examples/configurations/PE/interp/cheby_interp.c +++ b/gstlal-ugly/examples/configurations/PE/interp/cheby_interp.c @@ -1,3 +1,6 @@ +/* Use old lal complex structures for now */ +#define LAL_USE_OLD_COMPLEX_STRUCTS + #include <cheby_interp.h> #include <math.h> #include <gsl/gsl_math.h> @@ -17,6 +20,7 @@ #include <lal/FrequencySeries.h> #include <lal/LALConstants.h> #include <lal/Sequence.h> +#include <assert.h> /*#include <spa.c>*/ /* * Data structure methods @@ -66,8 +70,10 @@ static gsl_matrix_complex *projection_coefficient(gsl_vector *svd_basis, gsl_mat double M_real, M_imag; /* compute M_ky at fixed mu */ gsl_matrix_complex *M_xy = gsl_matrix_complex_calloc(N_mc, M_eta); - - for (unsigned int k =0; k < (template_bank->size1*template_bank->size2)/2; k++){ + + assert(N_mc * M_eta == template_bank->size1 / 2); + + for (unsigned int k =0; k < template_bank->size1 / 2; k++){ i = floor(k/N_mc); j = k - floor(k/N_mc)*N_mc; /* indices for M_xy */ @@ -79,7 +85,7 @@ static gsl_matrix_complex *projection_coefficient(gsl_vector *svd_basis, gsl_mat gsl_blas_ddot(&spa_waveform_imag.vector, svd_basis, &M_imag); GSL_SET_COMPLEX(&M, M_real, M_imag); - gsl_matrix_complex_set(M_xy, i, j, M); + gsl_matrix_complex_set(M_xy, i, j, M); } @@ -403,19 +409,19 @@ static int get_psd_from_file(REAL8FrequencySeries *series, char *fname){ double f0 = series->f0; double f; const gsl_interp_type *t = gsl_interp_linear; - gsl_interp *g_interp = gsl_interp_alloc (t, 16385); + gsl_interp *g_interp = gsl_interp_alloc (t, 16384); gsl_interp_accel *acc = gsl_interp_accel_alloc(); - double freq[16385]; - double psd[16385]; + double freq[16384]; + double psd[16384]; - int i; - fp = fopen("nameoffile", "r"); + int i = 0; while (!feof(fp)) { - fscanf(fp, "%f %e", &freq[i], &psd[i]); + if (i >= 16384) break; + fscanf(fp, "%lf %le\n", &freq[i], &psd[i]); i++; } - gsl_interp_init(g_interp, freq, psd, 16385); + gsl_interp_init(g_interp, freq, psd, 16384); for (i = 0; i < series->data->length; i++) { f = f0 + i * deltaF; @@ -601,6 +607,7 @@ static gsl_matrix *create_svd_basis_from_template_bank(gsl_matrix* template_bank template_view = gsl_matrix_submatrix(template_bank, 0, 0, n, template_bank->size2); output = gsl_matrix_calloc(n, template_bank->size2); + fprintf(stderr, "output size %d %d\n", output->size1, output->size2); gsl_matrix_memcpy(output, &template_view.matrix); return output; } diff --git a/gstlal-ugly/examples/configurations/PE/interp/compiles.sh b/gstlal-ugly/examples/configurations/PE/interp/compiles.sh index 698b7892d515ec927f76f4865e61f6538ebd9ef7..b4183ea6fa3ddda8b11f02c23869acd69d623584 100644 --- a/gstlal-ugly/examples/configurations/PE/interp/compiles.sh +++ b/gstlal-ugly/examples/configurations/PE/interp/compiles.sh @@ -1 +1,2 @@ -gcc -l $(pkg-config --libs gsl lal) cheby_interp.c -I./ -I/home/channa/gstopt/include --std=gnu99 +gcc -g $(pkg-config --libs lal) cheby_interp.c -I./ -I/home/channa/gstopt/include --std=gnu99 +#gcc -l $(pkg-config --libs gsl lal) cheby_interp.c -I./ -I/home/channa/gstopt/include --std=gnu99 diff --git a/gstlal-ugly/examples/configurations/PE/interp/runme.sh b/gstlal-ugly/examples/configurations/PE/interp/runme.sh index 8c21eaff04e76d7bbdf774f792d60c83d93784c6..27a30fbe29a44429a2d74a4a655b0fd9cd433845 100644 --- a/gstlal-ugly/examples/configurations/PE/interp/runme.sh +++ b/gstlal-ugly/examples/configurations/PE/interp/runme.sh @@ -1 +1,6 @@ -./plot_svd ../bank/svd_bank.xml.gz ../bank/test_bank.xml.gz +# edit for your own path +# to run in gdb do this\ +# LD_PRELOAD=/home/channa/gstopt/lib/liblal.so.3 gdb +# (gdb) run +LD_PRELOAD=/home/channa/gstopt/lib/liblal.so.3 ./a.out +#./plot_svd ../bank/svd_bank.xml.gz ../bank/test_bank.xml.gz