version 1.33, 2015/01/25 18:28:41
|
version 1.34, 2015/02/27 19:50:37
|
Line 1975 void computeSWIndex(struct swIndex *swKe |
|
Line 1975 void computeSWIndex(struct swIndex *swKe |
|
float *jz_rms_err = (float *) (malloc(nxny * sizeof(float))); | float *jz_rms_err = (float *) (malloc(nxny * sizeof(float))); |
float *err_term1 = (float *) (malloc(nxny * sizeof(float))); | float *err_term1 = (float *) (malloc(nxny * sizeof(float))); |
float *err_term2 = (float *) (malloc(nxny * sizeof(float))); | float *err_term2 = (float *) (malloc(nxny * sizeof(float))); |
|
float *err_termA = (float *) (calloc(nxny, sizeof(float))); |
|
float *err_termB = (float *) (calloc(nxny, sizeof(float))); |
|
float *err_termAt = (float *) (calloc(nxny, sizeof(float))); |
|
float *err_termBt = (float *) (calloc(nxny, sizeof(float))); |
|
float *err_termAh = (float *) (calloc(nxny, sizeof(float))); |
|
float *err_termBh = (float *) (calloc(nxny, sizeof(float))); |
| |
// define some values for the R calculation | // define some values for the R calculation |
int scale = round(2.0/cdelt1); | int scale = round(2.0/cdelt1); |
Line 2022 void computeSWIndex(struct swIndex *swKe |
|
Line 2028 void computeSWIndex(struct swIndex *swKe |
|
computeB_total(bx_err, by_err, bz_err, bt_err, bx, by, bz, bt, dims, mask, bitmask); | computeB_total(bx_err, by_err, bz_err, bt_err, bx, by, bz, bt, dims, mask, bitmask); |
| |
if (computeBtotalderivative(bt, dims, &(swKeys_ptr->mean_derivative_btotal), mask, bitmask, derx_bt, | if (computeBtotalderivative(bt, dims, &(swKeys_ptr->mean_derivative_btotal), mask, bitmask, derx_bt, |
dery_bt, bt_err, &(swKeys_ptr->mean_derivative_btotal_err))) |
dery_bt, bt_err, &(swKeys_ptr->mean_derivative_btotal_err), err_termAt, err_termBt)) |
{ | { |
swKeys_ptr->mean_derivative_btotal = DRMS_MISSING_FLOAT; | swKeys_ptr->mean_derivative_btotal = DRMS_MISSING_FLOAT; |
swKeys_ptr->mean_derivative_btotal_err = DRMS_MISSING_FLOAT; | swKeys_ptr->mean_derivative_btotal_err = DRMS_MISSING_FLOAT; |
} | } |
| |
if (computeBhderivative(bh, bh_err, dims, &(swKeys_ptr->mean_derivative_bh), | if (computeBhderivative(bh, bh_err, dims, &(swKeys_ptr->mean_derivative_bh), |
&(swKeys_ptr->mean_derivative_bh_err), mask, bitmask, derx_bh, dery_bh)) |
&(swKeys_ptr->mean_derivative_bh_err), mask, bitmask, derx_bh, dery_bh, err_termAh, err_termBh)) |
{ | { |
swKeys_ptr->mean_derivative_bh = DRMS_MISSING_FLOAT; | swKeys_ptr->mean_derivative_bh = DRMS_MISSING_FLOAT; |
swKeys_ptr->mean_derivative_bh_err = DRMS_MISSING_FLOAT; | swKeys_ptr->mean_derivative_bh_err = DRMS_MISSING_FLOAT; |
} | } |
| |
if (computeBzderivative(bz, bz_err, dims, &(swKeys_ptr->mean_derivative_bz), &(swKeys_ptr->mean_derivative_bz_err), | if (computeBzderivative(bz, bz_err, dims, &(swKeys_ptr->mean_derivative_bz), &(swKeys_ptr->mean_derivative_bz_err), |
mask, bitmask, derx_bz, dery_bz)) |
mask, bitmask, derx_bz, dery_bz, err_termA, err_termB)) |
{ | { |
swKeys_ptr->mean_derivative_bz = DRMS_MISSING_FLOAT; // If fail, fill in NaN | swKeys_ptr->mean_derivative_bz = DRMS_MISSING_FLOAT; // If fail, fill in NaN |
swKeys_ptr->mean_derivative_bz_err = DRMS_MISSING_FLOAT; | swKeys_ptr->mean_derivative_bz_err = DRMS_MISSING_FLOAT; |
Line 2122 void computeSWIndex(struct swIndex *swKe |
|
Line 2128 void computeSWIndex(struct swIndex *swKe |
|
| |
} | } |
| |
|
|
// Clean up the arrays | // Clean up the arrays |
| |
drms_free_array(bitmaskArray); // Dec 18 2012 Xudong | drms_free_array(bitmaskArray); // Dec 18 2012 Xudong |
Line 2144 void computeSWIndex(struct swIndex *swKe |
|
Line 2149 void computeSWIndex(struct swIndex *swKe |
|
free(bt_err); free(bh_err); free(jz_err); | free(bt_err); free(bh_err); free(jz_err); |
free(jz_err_squared); free(jz_rms_err); | free(jz_err_squared); free(jz_rms_err); |
free(jz_err_squared_smooth); | free(jz_err_squared_smooth); |
|
|
|
// free the arrays that are related to the numerical derivatives |
free(err_term2); | free(err_term2); |
free(err_term1); | free(err_term1); |
|
free(err_termB); |
|
free(err_termA); |
|
free(err_termBt); |
|
free(err_termAt); |
|
free(err_termBh); |
|
free(err_termAh); |
| |
// free the arrays that are related to the r calculation | // free the arrays that are related to the r calculation |
free(rim); | free(rim); |