(file) Return to sharp.c CVS log (file) (dir) Up to [Development] / JSOC / proj / sharp / apps

Diff for /JSOC/proj/sharp/apps/sharp.c between version 1.38 and 1.39

version 1.38, 2015/03/18 00:28:26 version 1.39, 2021/05/24 22:17:37
Line 147 
Line 147 
 // Space weather keywords // Space weather keywords
 struct swIndex { struct swIndex {
     float mean_vf;     float mean_vf;
       float mean_vf_los;
     float count_mask;     float count_mask;
       float count_mask_los;
     float absFlux;     float absFlux;
       float absFlux_los;
     float mean_hf;     float mean_hf;
     float mean_gamma;     float mean_gamma;
     float mean_derivative_btotal;     float mean_derivative_btotal;
     float mean_derivative_bh;     float mean_derivative_bh;
     float mean_derivative_bz;     float mean_derivative_bz;
       float mean_derivative_los;
     float mean_jz;     float mean_jz;
     float us_i;     float us_i;
     float mean_alpha;     float mean_alpha;
Line 1978  void computeSWIndex(struct swIndex *swKe
Line 1982  void computeSWIndex(struct swIndex *swKe
         float *bpz     = (float *) (malloc(nxny * sizeof(float)));         float *bpz     = (float *) (malloc(nxny * sizeof(float)));
         float *derx    = (float *) (malloc(nxny * sizeof(float)));         float *derx    = (float *) (malloc(nxny * sizeof(float)));
         float *dery    = (float *) (malloc(nxny * sizeof(float)));         float *dery    = (float *) (malloc(nxny * sizeof(float)));
           float *derx_los = (float *) (malloc(nxny * sizeof(float)));
           float *dery_los = (float *) (malloc(nxny * sizeof(float)));
         float *derx_bt = (float *) (malloc(nxny * sizeof(float)));         float *derx_bt = (float *) (malloc(nxny * sizeof(float)));
         float *dery_bt = (float *) (malloc(nxny * sizeof(float)));         float *dery_bt = (float *) (malloc(nxny * sizeof(float)));
         float *derx_bh = (float *) (malloc(nxny * sizeof(float)));         float *derx_bh = (float *) (malloc(nxny * sizeof(float)));
Line 2031  void computeSWIndex(struct swIndex *swKe
Line 2037  void computeSWIndex(struct swIndex *swKe
                 swKeys_ptr->count_mask  = DRMS_MISSING_INT;                 swKeys_ptr->count_mask  = DRMS_MISSING_INT;
         }         }
  
           if (computeAbsFlux_los(los, dims, &(swKeys_ptr->absFlux_los), &(swKeys_ptr->mean_vf_los),
                              &(swKeys_ptr->count_mask_los), bitmask, cdelt1, rsun_ref, rsun_obs))
           {
                   swKeys_ptr->absFlux_los = DRMS_MISSING_FLOAT;               // If fail, fill in NaN
                   swKeys_ptr->mean_vf_los = DRMS_MISSING_FLOAT;
                   swKeys_ptr->count_mask_los = DRMS_MISSING_INT;
           }
   
         for (int i = 0; i < nxny; i++) bpz[i] = bz[i];         for (int i = 0; i < nxny; i++) bpz[i] = bz[i];
         greenpot(bpx, bpy, bpz, nx, ny);         greenpot(bpx, bpy, bpz, nx, ny);
  
Line 2065  void computeSWIndex(struct swIndex *swKe
Line 2079  void computeSWIndex(struct swIndex *swKe
                 swKeys_ptr->mean_derivative_bz_err = DRMS_MISSING_FLOAT;                 swKeys_ptr->mean_derivative_bz_err = DRMS_MISSING_FLOAT;
         }         }
  
           if (computeLOSderivative(los, dims, &(swKeys_ptr->mean_derivative_los), bitmask, derx_los, dery_los))
           {
                   swKeys_ptr->mean_derivative_los = DRMS_MISSING_FLOAT; // If fail, fill in NaN
           }
   
         computeJz(bx_err, by_err, bx, by, dims, jz, jz_err, jz_err_squared, mask, bitmask, cdelt1, rsun_ref, rsun_obs,         computeJz(bx_err, by_err, bx, by, dims, jz, jz_err, jz_err_squared, mask, bitmask, cdelt1, rsun_ref, rsun_obs,
                   derx, dery, err_term1, err_term2);                   derx, dery, err_term1, err_term2);
  
Line 2163  void computeSWIndex(struct swIndex *swKe
Line 2182  void computeSWIndex(struct swIndex *swKe
         free(derx_bt); free(dery_bt);         free(derx_bt); free(dery_bt);
         free(derx_bz); free(dery_bz);         free(derx_bz); free(dery_bz);
         free(derx_bh); free(dery_bh);         free(derx_bh); free(dery_bh);
           free(derx_los); free(dery_los);
         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);
Line 2200  void computeSWIndex(struct swIndex *swKe
Line 2220  void computeSWIndex(struct swIndex *swKe
 void setSWIndex(DRMS_Record_t *outRec, struct swIndex *swKeys_ptr) void setSWIndex(DRMS_Record_t *outRec, struct swIndex *swKeys_ptr)
 { {
     drms_setkey_float(outRec, "USFLUX",  swKeys_ptr->mean_vf);     drms_setkey_float(outRec, "USFLUX",  swKeys_ptr->mean_vf);
       drms_setkey_float(outRec, "USFLUXL", swKeys_ptr->mean_vf_los);
     drms_setkey_float(outRec, "MEANGAM", swKeys_ptr->mean_gamma);     drms_setkey_float(outRec, "MEANGAM", swKeys_ptr->mean_gamma);
     drms_setkey_float(outRec, "MEANGBT", swKeys_ptr->mean_derivative_btotal);     drms_setkey_float(outRec, "MEANGBT", swKeys_ptr->mean_derivative_btotal);
     drms_setkey_float(outRec, "MEANGBH", swKeys_ptr->mean_derivative_bh);     drms_setkey_float(outRec, "MEANGBH", swKeys_ptr->mean_derivative_bh);
     drms_setkey_float(outRec, "MEANGBZ", swKeys_ptr->mean_derivative_bz);     drms_setkey_float(outRec, "MEANGBZ", swKeys_ptr->mean_derivative_bz);
       drms_setkey_float(outRec, "MEANGBL", swKeys_ptr->mean_derivative_los);
     drms_setkey_float(outRec, "MEANJZD", swKeys_ptr->mean_jz);     drms_setkey_float(outRec, "MEANJZD", swKeys_ptr->mean_jz);
     drms_setkey_float(outRec, "TOTUSJZ", swKeys_ptr->us_i);     drms_setkey_float(outRec, "TOTUSJZ", swKeys_ptr->us_i);
     drms_setkey_float(outRec, "MEANALP", swKeys_ptr->mean_alpha);     drms_setkey_float(outRec, "MEANALP", swKeys_ptr->mean_alpha);
Line 2216  void setSWIndex(DRMS_Record_t *outRec, s
Line 2238  void setSWIndex(DRMS_Record_t *outRec, s
     drms_setkey_float(outRec, "MEANSHR", swKeys_ptr->meanshear_angle);     drms_setkey_float(outRec, "MEANSHR", swKeys_ptr->meanshear_angle);
     drms_setkey_float(outRec, "SHRGT45", swKeys_ptr->area_w_shear_gt_45);     drms_setkey_float(outRec, "SHRGT45", swKeys_ptr->area_w_shear_gt_45);
     drms_setkey_float(outRec, "CMASK",   swKeys_ptr->count_mask);     drms_setkey_float(outRec, "CMASK",   swKeys_ptr->count_mask);
       drms_setkey_float(outRec, "CMASKL",  swKeys_ptr->count_mask_los);
     drms_setkey_float(outRec, "ERRBT",   swKeys_ptr->mean_derivative_btotal_err);     drms_setkey_float(outRec, "ERRBT",   swKeys_ptr->mean_derivative_btotal_err);
     drms_setkey_float(outRec, "ERRVF",   swKeys_ptr->mean_vf_err);     drms_setkey_float(outRec, "ERRVF",   swKeys_ptr->mean_vf_err);
     drms_setkey_float(outRec, "ERRGAM",  swKeys_ptr->mean_gamma_err);     drms_setkey_float(outRec, "ERRGAM",  swKeys_ptr->mean_gamma_err);


Legend:
Removed from v.1.38  
changed lines
  Added in v.1.39

Karen Tian
Powered by
ViewCVS 0.9.4