00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #include "limbfit.h"
00019
00020 char *module_name = "lfwrp";
00021
00022 ModuleArgs_t module_args[] = {
00023 {ARG_STRING, "dsin", "hmi.lev1", "input data set (default=hmi.lev1)"},
00024 {ARG_STRING, "dsout", "su_scholl.limbfit", "output data set"},
00025 {ARG_STRING, "logdir", "./", "logs directory"},
00026 {ARG_STRING, "tmpdir", "./", "tmp directory"},
00027 {ARG_STRING, "bdate", " ", "begin date"},
00028
00029 {ARG_INTS, "bfsn", "0", "first lev1 fsn# to process"},
00030 {ARG_INTS, "efsn", "0", "last lev1 fsn# to process"},
00031 {ARG_INT, "cam", "0", "camera selection: 0: both = default, otherwise: 1 or 2"},
00032 {ARG_INT, "fid", "0", "default=all, otherwise one FID number or mask"},
00033
00034 {ARG_INT, "spe", "0", "used to activate only 1 iteration of the FORTRAN code and AHI low for roll analaysis (default=0 normal processing - =1 activate)"},
00035 {ARG_INT, "cc", "0", "used to activate center calculation instead of using X0/YO_LF (default=0 no center calculation, =1 calculation)"},
00036 {ARG_INT, "iter", "3", "to change the number of iterations of the limb.f code (default=3)"},
00037 {ARG_INT, "fldf", "0", "0: no full ldf processing (default), 1: with full ldf proc."},
00038 {ARG_INT, "src", "0", "0: hmi.lev1 (default), 1: hmi.lev1_nrt (quality test is different)"},
00039
00040 {ARG_STRING, "comment", " ", "to add a comment in a dataset"},
00041 {ARG_STRING, "preset", "all", "current possible values: roll_cont, roll_all, pipeline, pipeline2, all, none (default=all <=> cam and fid selection)"},
00042 {ARG_INT, "debug", "0", "debug level (default: 0 no debug info)"},
00043 {ARG_END}
00044
00045 };
00046
00047 void get_sdate(char *sdate)
00048 {
00049
00050 time_t t = time(NULL);
00051 struct tm *timeptr;
00052
00053 timeptr = localtime(&t);
00054 sprintf(sdate, "%d.%02d.%02d_%02d:%02d:%02d",
00055 (timeptr->tm_year+1900), (timeptr->tm_mon+1),
00056 timeptr->tm_mday, timeptr->tm_hour, timeptr->tm_min, timeptr->tm_sec);
00057 }
00058
00059
00060 void lf_logmsg(char * type1, char * type2, int return_code, int status, char *message, char *code_name, FILE *opf)
00061 {
00062 static char sdate[32];
00063 get_sdate(sdate);
00064 if ( !(strcmp(type1,"INFO")) || (status==0 &&return_code==0))
00065 fprintf(opf,"%s/%20s: %s %5s %5s msg: '%s' \n",LOGMSG1, code_name, sdate,type1,type2, message);
00066 else
00067 fprintf(opf,"%s/%20s: %s %5s %5s msg: '%s' return code: %d exit: %d\n",LOGMSG1, code_name, sdate,type1,type2, message, return_code,status);
00068 }
00069
00070 void close_on_error(DRMS_Record_t *record_in,DRMS_Record_t *record_out,DRMS_Array_t *data_array)
00071 {
00072 drms_free_array (data_array);
00073 drms_close_record (record_out, DRMS_FREE_RECORD);
00074 drms_close_record (record_in, DRMS_FREE_RECORD);
00075
00076 }
00077
00078
00079
00080
00081
00082 int process_n_records_fsn(char * open_dsname, LIMBFIT_INPUT *lfv, LIMBFIT_OUTPUT *lfr, LIMBFIT_IO_PUT *lfw, int *status)
00083 {
00084 static char *log_msg_code="process_n_records";
00085 char log_msg[200];
00086 sprintf(log_msg,"doing process for %s -> %s",open_dsname,lfr->dsout);
00087 lf_logmsg("INFO", "APP", 0,0, log_msg, log_msg_code, lfr->opf);
00088
00089
00090
00091
00092
00093
00094
00095 DRMS_RecordSet_t *drs_in,*drs_out;
00096 DRMS_Record_t *record_in,*record_out;
00097 int rstatus, ncnt,r;
00098
00099 drs_in = drms_open_records(drms_env, open_dsname, &rstatus);
00100 if (!drs_in) {
00101 sprintf(log_msg,"unable to open record set %s\n",open_dsname);
00102 lf_logmsg("ERROR", "DRMS", ERR_DRMS_READ, rstatus, log_msg, log_msg_code, lfr->opf);
00103 fprintf (stderr, log_msg);
00104 *status=ERR_DRMS_READ;
00105 return(ERR_DRMS_READ);
00106 }
00107
00108 ncnt = drs_in->n;
00109 if (ncnt < 1) {
00110 sprintf(log_msg,"no records in selected set %s\n",open_dsname);
00111 lf_logmsg("WARNING", "DRMS", WAR_DRMS_NORECORD, rstatus, log_msg, log_msg_code, lfr->opf);
00112 fprintf (stderr, log_msg);
00113 *status=WAR_DRMS_NORECORD;
00114 drms_close_records(drs_in, DRMS_FREE_RECORD);
00115 return(WAR_DRMS_NORECORD);
00116 }
00117
00118 drs_out = drms_create_records(drms_env, ncnt, lfr->dsout, DRMS_PERMANENT,&rstatus);
00119 if (!drs_out) {
00120 sprintf(log_msg,"unable to create record set %s\n",lfr->dsout);
00121 lf_logmsg("ERROR", "DRMS", ERR_DRMS_WRITE, rstatus, log_msg, log_msg_code, lfr->opf);
00122 fprintf (stderr, log_msg);
00123 *status=ERR_DRMS_WRITE;
00124 drms_close_records(drs_in, DRMS_FREE_RECORD);
00125 return(ERR_DRMS_WRITE);
00126 }
00127
00128 unsigned int fsn = 0;
00129
00130 for(r=0; r < ncnt; r++)
00131 {
00132 record_in = drs_in->records[r];
00133 record_out = drs_out->records[r];
00134
00135 fsn = drms_getkey_int(record_in, "FSN", &rstatus);
00136 if(rstatus) {
00137 lf_logmsg("ERROR", "DRMS", ERR_DRMS_READ_MISSING_KW, rstatus, "drms_getkey_string(FSN)", log_msg_code, lfr->opf);
00138 write_mini_output(PROCSTAT_NO_LF_DB_READ_PB,record_in,record_out,0,lfr);
00139 *status=ERR_DRMS_READ_MISSING_KW;
00140 drms_close_records(drs_out, DRMS_INSERT_RECORD);
00141 drms_close_records(drs_in, DRMS_FREE_RECORD);
00142 return(rstatus);
00143 }
00144 sprintf(log_msg,"FSN:%u processing",fsn);
00145 lf_logmsg("INFO", "APP", 0,0, log_msg, log_msg_code, lfr->opf);
00146 printf("selection: #%u\n",fsn);
00147
00148 if (do_one_limbfit(fsn,record_in,record_out,lfv,lfr,lfw,&rstatus))
00149 {
00150 if (rstatus < 0 && rstatus > -300)
00151 {
00152 drms_close_records(drs_out, DRMS_INSERT_RECORD);
00153 drms_close_records(drs_in, DRMS_FREE_RECORD);
00154 lf_logmsg("ERROR", "APP", rstatus, 0, "to be aborted", log_msg_code, lfr->opf);
00155 return(rstatus);
00156 }
00157 }
00158 fflush(lfr->opf);
00159 }
00160 drms_close_records(drs_out, DRMS_INSERT_RECORD);
00161 drms_close_records(drs_in, DRMS_FREE_RECORD);
00162 lf_logmsg("INFO", "APP", 0, 0, "Records saved", log_msg_code, lfr->opf);
00163 if (lfr->debug) printf("records saved\n");
00164
00165 return(0);
00166 }
00167
00168 int process_all_records_smpl(char * open_dsname, LIMBFIT_INPUT *lfv, LIMBFIT_OUTPUT *lfr, LIMBFIT_IO_PUT *lfw, int *status)
00169 {
00170 static char *log_msg_code="process_n_records";
00171 char log_msg[200];
00172 sprintf(log_msg,"doing process for %s -> %s",open_dsname,lfr->dsout);
00173 lf_logmsg("INFO", "APP", 0,0, log_msg, log_msg_code, lfr->opf);
00174
00175
00176 DRMS_RecordSet_t *drs_in,*drs_out;
00177 DRMS_Record_t *record_in,*record_out;
00178 int rstatus;
00179 long long ncnt;
00180 unsigned int fsn = 0;
00181
00182 drs_in = drms_open_records(drms_env, open_dsname, &rstatus);
00183 if (!drs_in) {
00184 sprintf(log_msg,"unable to open record set %s\n",open_dsname);
00185 lf_logmsg("ERROR", "DRMS", ERR_DRMS_READ, rstatus, log_msg, log_msg_code, lfr->opf);
00186 fprintf (stderr, log_msg);
00187 *status=ERR_DRMS_READ;
00188 return(ERR_DRMS_READ);
00189 }
00190 ncnt = drs_in->n;
00191 if (ncnt < 1) {
00192 sprintf(log_msg,"no records in selected set %s\n",open_dsname);
00193 lf_logmsg("WARNING", "DRMS", WAR_DRMS_NORECORD, rstatus, log_msg, log_msg_code, lfr->opf);
00194 fprintf (stderr, log_msg);
00195 *status=WAR_DRMS_NORECORD;
00196 drms_close_records(drs_in, DRMS_FREE_RECORD);
00197 return(WAR_DRMS_NORECORD);
00198 }
00199
00200 sprintf(log_msg,"---> %lld records",ncnt);
00201 lf_logmsg("INFO", "APP", 0,0, log_msg, log_msg_code, lfr->opf);
00202
00203
00204
00205
00206 long long numofrecs, nrec, n, j;
00207 int numrec, numofchunks, i;
00208 numofrecs = ncnt;
00209 numrec = NUMRECPERTRANS;
00210 numofchunks = numofrecs/numrec;
00211 if((numofrecs % numrec) != 0) numofchunks++;
00212 n=0;
00213 for(i = 0; i < numofchunks; i++)
00214 {
00215 if ((ncnt-n)>=numrec) nrec=numrec; else nrec=ncnt-n;
00216
00217 drs_out = drms_create_records(drms_env, nrec, lfr->dsout, DRMS_PERMANENT,&rstatus);
00218 if (!drs_out) {
00219 sprintf(log_msg,"unable to create record set %s\n",lfr->dsout);
00220 lf_logmsg("ERROR", "DRMS", ERR_DRMS_WRITE, rstatus, log_msg, log_msg_code, lfr->opf);
00221 fprintf (stderr, log_msg);
00222 *status=ERR_DRMS_WRITE;
00223 drms_close_records(drs_in, DRMS_FREE_RECORD);
00224 return(ERR_DRMS_WRITE);
00225 }
00226 for(j=0; j<numrec && n<ncnt; j++)
00227 {
00228 record_in = drs_in->records[n];
00229 record_out = drs_out->records[j];
00230
00231 fsn = drms_getkey_int(record_in, "FSN", &rstatus);
00232 if(rstatus) {
00233 lf_logmsg("ERROR", "DRMS", ERR_DRMS_READ_MISSING_KW, rstatus, "drms_getkey_string(FSN)", log_msg_code, lfr->opf);
00234 write_mini_output(PROCSTAT_NO_LF_DB_READ_PB,record_in,record_out,0,lfr);
00235 *status=ERR_DRMS_READ_MISSING_KW;
00236 drms_close_records(drs_out, DRMS_INSERT_RECORD);
00237 drms_close_records(drs_in, DRMS_FREE_RECORD);
00238 return(rstatus);
00239 }
00240 sprintf(log_msg,"FSN:%u processing",fsn);
00241 lf_logmsg("INFO", "APP", 0,0, log_msg, log_msg_code, lfr->opf);
00242 printf("selection: #%u\n",fsn);
00243
00244 if (do_one_limbfit(fsn,record_in,record_out,lfv,lfr,lfw,&rstatus))
00245 {
00246 if (rstatus < 0 && rstatus > -300)
00247 {
00248 drms_close_records(drs_out, DRMS_INSERT_RECORD);
00249 drms_close_records(drs_in, DRMS_FREE_RECORD);
00250 lf_logmsg("ERROR", "APP", rstatus, 0, "to be aborted", log_msg_code, lfr->opf);
00251 return(rstatus);
00252 }
00253 }
00254 fflush(lfr->opf);
00255 n++;
00256 }
00257 drms_close_records(drs_out, DRMS_INSERT_RECORD);
00258 lf_logmsg("INFO", "APP", 0, 0, "Records saved", log_msg_code, lfr->opf);
00259 if (lfr->debug) printf("records saved\n");
00260 drms_server_end_transaction(drms_env,0,0);
00261 drms_server_begin_transaction(drms_env);
00262 }
00263 drms_close_records(drs_in, DRMS_FREE_RECORD);
00264 sprintf(log_msg,"close %s", open_dsname);
00265 lf_logmsg("INFO", "APP", 0, 0, log_msg, log_msg_code, lfr->opf);
00266
00267 return(0);
00268 }
00269
00270
00271
00272
00273
00274
00275
00276 int DoIt(void)
00277 {
00278
00279
00280 CmdParams_t *params = &cmdparams;
00281
00282 int debug = params_get_int (params, "debug");
00283 int spe = params_get_int (params, "spe");
00284 int cc = params_get_int (params, "cc");
00285 int fldf = params_get_int (params, "fldf");
00286 int iter = params_get_int (params, "iter");
00287 int cam = params_get_int (params, "cam");
00288 int fid = params_get_int (params, "fid");
00289
00290 int src = params_get_int (params, "src");
00291
00292 char* dsin = params_get_str (params, "dsin");
00293 char* dsout = params_get_str (params, "dsout");
00294 char* log_dir = params_get_str (params, "logdir");
00295 char* tmp_dir = params_get_str (params, "tmpdir");
00296 char* preset = params_get_str (params, "preset");
00297 char* comment = params_get_str (params, "comment");
00298 long long bfsn = params_get_int (params, "bfsn");
00299 long long efsn = params_get_int (params, "efsn");
00300 char* bdate = params_get_str (params, "bdate");
00301
00302
00303 static char *log_msg_code="DoIt";
00304 char log_msg[200];
00305 int result;
00306
00307 static char open_dsname[400];
00308 char recrange[128];
00309 static char qual[15];
00310
00311 if ((bfsn == 0 || efsn == 0) && strcmp(bdate," ")==0)
00312 {
00313 fprintf(stderr, "bfsn and efsn must be given for fsn mode or begin date must be specified. \n");
00314 return(ERR_EXIT);
00315 }
00316 if(strcmp(bdate," ")==0 && bfsn > efsn)
00317 {
00318 fprintf(stderr, "bfsn must be <= efsn\n");
00319 return(ERR_EXIT);
00320 }
00321 if(cam < 0 || cam > 2)
00322 {
00323 fprintf(stderr, "cam must be equal to 0, 1, or 2\n");
00324 return(ERR_EXIT);
00325 }
00326 if(src == 0)
00327 sprintf(qual,"0");
00328 else
00329 sprintf(qual,"1073741824");
00330
00331 static char bld_vers[16];
00332 sprintf(bld_vers, "%s", jsoc_version);
00333
00334
00335
00336
00337 static char flogname[128];
00338 static char sdate[32];
00339 get_sdate(sdate);
00340
00341 FILE *opf;
00342 sprintf(flogname, "%s/limbfit_%s_%lld_%lld.log",log_dir,sdate,bfsn,efsn);
00343 if((opf=fopen(flogname, "w")) == NULL)
00344 {
00345 fprintf(stderr, "**Can't open the log file %s\n", flogname);
00346 return(ERR_EXIT);
00347 }
00348 lf_logmsg("INFO", "APP", 0, 0, "Begin... ", log_msg_code, opf);
00349
00350
00351 static char tcam[20];
00352 static char tfid[100];
00353 static char tdat[50];
00354 static char tfil[30];
00355 static char tbase[128];
00356 sprintf(tfil, "[? quality = %s ", qual);
00357 int presetval=0;
00358
00359 if(strcmp(preset,"ppl1d")==0)
00360 {
00361 sprintf(tcam, " and camera=2 ");
00362 sprintf(tfid, " and CAST(FID AS TEXT) LIKE '%8'");
00363 sprintf(tdat, "[%s]",bdate);
00364 presetval=10;
00365 }
00366 else if(strcmp(preset,"ppl2d")==0)
00367 {
00368 sprintf(tcam, " and camera=1 ");
00369 sprintf(tfid, " and FID<10010 ");
00370 sprintf(tdat, "[%s]",bdate);
00371 presetval=10;
00372 }
00373 else if(strcmp(preset,"ppl3d")==0)
00374 {
00375 sprintf(tcam, " and camera=1 ");
00376 sprintf(tfid, " and FID>10010 and hftsacid = 1021 and hflreftm % 540 = 135 ");
00377 sprintf(tdat, "[%s]",bdate);
00378
00379 presetval=10;
00380 }
00381 else if(strcmp(preset,"roll_all")==0 || strcmp(preset,"all")==0)
00382 {
00383 sprintf(tcam, " ");
00384 sprintf(tfid, " ");
00385 presetval=20;
00386 }
00387 else if(strcmp(preset,"roll_cont")==0)
00388 {
00389 sprintf(tcam, " ");
00390 sprintf(tfid, " AND FID<10010 ");
00391 presetval=20;
00392 }
00393 else
00394 {
00395 if (cam == 1 || cam == 2) sprintf(tcam, " and camera = %d ", cam); else sprintf(tcam, " ");
00396 if (fid != 0) sprintf(tfid, " and fid = %d ", fid); else sprintf(tfid, " ");
00397 presetval=20;
00398 }
00399
00400 sprintf(tbase, "%s%s%s ?]", tfil,tcam,tfid);
00401
00402
00403
00404
00405
00406
00407 float * anls = (float *) malloc(sizeof(float)*(MAX_SIZE_ANN_VARS*3));
00408 if(!anls)
00409 {
00410 lf_logmsg("ERROR", "APP", ERR_MALLOC_FAILED, 0,"malloc failed (anls)", log_msg_code, opf);
00411 return(ERR_EXIT);
00412 }
00413
00414
00415
00416
00417 static LIMBFIT_INPUT limbfit_vars ;
00418 static LIMBFIT_INPUT *lfv = &limbfit_vars;
00419 static LIMBFIT_OUTPUT limbfit_res ;
00420 static LIMBFIT_OUTPUT *lfr = &limbfit_res;
00421 static LIMBFIT_IO_PUT limbfit_ios ;
00422 static LIMBFIT_IO_PUT *lfw = &limbfit_ios;
00423
00424 lfr->code_name=CODE_NAME;
00425 lfr->code_version=CODE_VERSION;
00426 lfr->code_date=CODE_DATE;
00427 lfr->comment=comment;
00428 lfr->dsin=dsin;
00429 lfr->bld_vers=bld_vers;
00430 lfr->opf=opf;
00431 lfr->tmp_dir=tmp_dir;
00432 lfr->dsout=dsout;
00433 lfr->debug=debug;
00434
00435 lfv->cc=cc;
00436 lfv->spe=spe;
00437 lfv->iter=iter;
00438 lfv->fldf=fldf;
00439
00440
00441 lfw->anls=anls;
00442 lfw->is_firstobs=0;
00443 lfw->anls_nbpix=0;
00444 lfw->pf_anls=&anls[0];
00445
00446
00447
00448
00449
00450
00451 if(presetval==20)
00452 {
00453
00454
00455
00456 long long numofrecs, frec, lrec;
00457 int numrec, numofchunks, i;
00458 numofrecs = (efsn - bfsn) + 1;
00459 numrec = NUMRECPERTRANS;
00460 numofchunks = numofrecs/numrec;
00461 if((numofrecs % numrec) != 0) numofchunks++;
00462 lrec = bfsn-1;
00463
00464 for(i = 0; i < numofchunks; i++)
00465 {
00466 frec = lrec+1;
00467 lrec = (frec + numrec)-1;
00468 if(lrec > efsn) lrec=efsn;
00469 sprintf(recrange, "%lld-%lld", frec, lrec);
00470 sprintf(open_dsname, "%s[][%s]%s", dsin, recrange,tbase);
00471
00472 sprintf(log_msg,"open %s -> %s (logdir: %s, tmpdir: %s, cam: %d, spe: %d, cc: %d, iter: %d, comment: %s , debug: %d)",
00473 open_dsname,dsout,log_dir,tmp_dir,cam,spe,cc,iter,comment,debug);
00474
00475 lf_logmsg("INFO", "APP", 0, 0, log_msg, log_msg_code, opf);
00476 if(process_n_records_fsn(open_dsname, lfv, lfr, lfw, &result))
00477 {
00478 if (result < 0 && result > -400)
00479 {
00480 lf_logmsg("ERROR", "ABORT", result, 0, "", log_msg_code, opf);
00481 fprintf(opf,"lfwrp abort\nSee log: %s\n", flogname);
00482 fprintf(opf,"lfwrp: Restart it as %s[][%lld-%lld]%s\n", dsin,frec,efsn,tbase);
00483
00484 fclose(opf);
00485 return(ERR_EXIT);
00486 }
00487 }
00488 sprintf(log_msg,"close %s", open_dsname);
00489 lf_logmsg("INFO", "APP", 0, 0, log_msg, log_msg_code, opf);
00490 drms_server_end_transaction(drms_env,0,0);
00491 drms_server_begin_transaction(drms_env);
00492 }
00493 }
00494 else if(presetval==10)
00495 {
00496
00497 sprintf(open_dsname, "%s%s[]%s", dsin, tdat, tbase);
00498 sprintf(log_msg,"open %s -> %s (logdir: %s, tmpdir: %s, comment: %s , debug: %d)",
00499 open_dsname,dsout,log_dir,tmp_dir,comment,debug);
00500 lf_logmsg("INFO", "APP", 0, 0, log_msg, log_msg_code, opf);
00501 if(process_all_records_smpl(open_dsname, lfv, lfr, lfw, &result))
00502 {
00503 if (result < 0 && result > -400)
00504 {
00505 lf_logmsg("ERROR", "ABORT", result, 0, "", log_msg_code, opf);
00506 fprintf(opf,"lfwrp abort\nSee log: %s\n", flogname);
00507
00508 fclose(opf);
00509 return(ERR_EXIT);
00510 }
00511 }
00512 }
00513
00514 free(anls);
00515 lf_logmsg("INFO", "APP", 0, 0, "Batch End... ", log_msg_code, opf);
00516 fclose(opf);
00517 printf("Batch end\n");
00518
00519 return(0);
00520 }
00521