00001
00002
00003 #include "jsoc_main.h"
00004 #include "drms_types.h"
00005
00006 #if 0
00007 #include "cfitsio.h"
00008 #include "fitsio.h"
00009 #endif
00010
00011
00012 #define NONDAILY 1
00013
00014 #define NEWMAP 0
00015
00016 int set_statistics(DRMS_Segment_t *, DRMS_Array_t *, int);
00017
00018 char *module_name = "mhdtxt2jsoc";
00019 #define DIE(msg) {fflush(stdout);fprintf(stderr,"%s, status=%d\n",msg,status); return(status);}
00020 ModuleArgs_t module_args[] =
00021 {
00022 #if NONDAILY == 1
00023 {ARG_STRING, "in", "d3equidist144x72.txt", "Input text file."},
00024 {ARG_STRING, "out", "hmi.MHDcorona", "Target DRMS data series."},
00025 #if NEWMAP == 1
00026 {ARG_STRING, "synomap", "hmi.BrBlossynop_720s", "synoptic map series as string"},
00027 #else
00028 {ARG_STRING, "synomap", "hmi.Synoptic_Mr_720s", "synoptic map series as string"},
00029 #endif
00030 {ARG_STRING, "crdate", "-1", "date or CR as string"},
00031 {ARG_INT, "sphindx", "-1", "terms of pfss spherical harmonic poly. (negative for raw map)"},
00032 {ARG_INT, "inx", "144", "long. grid size of input MHD data, in the text file"},
00033 {ARG_INT, "iny", "72", "lat. grid size of input MHD data, in the text file"},
00034 {ARG_INT, "inz", "80", "rad. grid size of input MHD data, in the text file"},
00035 #else
00036 {ARG_STRING, "in", "d3equidist.txt", "Input text file."},
00037 {ARG_STRING, "out", "hmi.MHDcorona_daily_nrt", "Target DRMS data series."},
00038 #if NEWMAP == 1
00039 {ARG_STRING, "synomap", "hmi.BrBlosdailysynframe_720s_nrt", "synoptic map series as string"},
00040 #else
00041 {ARG_STRING, "synomap", "hmi.Mrdailysynframe_720s_nrt", "synoptic map series as string"},
00042 #endif
00043 {ARG_STRING, "crdate", "$", "date as string"},
00044 {ARG_INT, "sphindx", "5", "terms of pfss spherical harmonic poly. (negative for raw map)"},
00045 {ARG_INT, "inx", "72", "long. grid size of input MHD data, in the text file"},
00046 {ARG_INT, "iny", "36", "lat. grid size of input MHD data, in the text file"},
00047 {ARG_INT, "inz", "80", "rad. grid size of input MHD data, in the text file"},
00048 #endif
00049 {ARG_INT, "ichrbnd", "0", "index for choice of sub-alfvenic boundary treatement"},
00050 {ARG_END}
00051 };
00052
00053 int DoIt(void)
00054 {
00055 CmdParams_t *params = &cmdparams;
00056 const char *instrc = params_get_str(params, "in");
00057 const char *outstrc = params_get_str(params, "out");
00058 const char *crdatestrc = params_get_str(params, "crdate");
00059 const char *synostrc = params_get_str(params, "synomap");
00060 const int sphindxc = params_get_int(params, "sphindx");
00061 const int inxc = params_get_int(params, "inx");
00062 const int inyc = params_get_int(params, "iny");
00063 const int inzc = params_get_int(params, "inz");
00064 const int ichrbndc = params_get_int(params, "ichrbnd");
00065
00066 char *instr, *outstr, *crdatestr, *synostr;
00067 instr = strdup(instrc);
00068 outstr = strdup(outstrc);
00069 crdatestr = strdup(crdatestrc);
00070 synostr = strdup(synostrc);
00071 int isphindx = sphindxc;
00072 int nx = inxc;
00073 int ny = inyc;
00074 int nz = inzc;
00075 int ichrbnd = ichrbndc;
00076
00077
00078 DRMS_RecordSet_t *inRS, *outRS;
00079 DRMS_Record_t *outRec, *inRec;
00080 DRMS_Segment_t *outSeg, *inSeg;
00081 DRMS_Array_t *inArray, *outArray;
00082
00083
00084 int status;
00085 int i, j, k, n;
00086 double ddummy;
00087 char *strdummy;
00088
00089 char *mhdcorona_version();
00090
00091 #if NONDAILY == 1
00092 int ncr = atoi(crdatestr);
00093 if (ncr < 0)
00094 {
00095 printf("CR is not given, so quit. %d %s\n",ncr,crdatestr);
00096 return (-1);
00097 }
00098 #endif
00099
00100
00101 printf("Nx Ny Nz = %d %d %d\n",nx,ny,nz);
00102 float *mhd8all;
00103 mhd8all=(float *)malloc(sizeof(float)*(nx*ny*nz*8));
00104
00105
00106 int icount=0;
00107 {
00108 FILE *fp=NULL;
00109 fp=fopen(instr,"r");
00110 char line[256];
00111 if(fp == NULL)
00112 {
00113 printf("Fail to open file %s\n",instr);
00114 return 1;
00115 }
00116 while(fgets(line,256,fp) != NULL)
00117 {
00118 float rdummy;
00119 sscanf(line,"%e",&rdummy);
00120 mhd8all[icount]=rdummy;
00121 icount=icount+1;
00122 }
00123 fclose(fp);
00124 }
00125 printf("Num of data expected in text file %s : %d \n",instr,nx*ny*nz*8);
00126 printf("Num of data loaded : %d \n",icount);
00127
00128 for(k = 0; k < nz; k++){for(j = 0; j < ny; j++){for(i = 0; i < nx; i++){
00129 int idrs = i + j * nx + k * nx * ny;
00130 mhd8all[idrs+0*nx*ny*nz] = mhd8all[idrs+0*nx*ny*nz] / 1.0e8;
00131 mhd8all[idrs+3*nx*ny*nz] = - mhd8all[idrs+3*nx*ny*nz];
00132 mhd8all[idrs+6*nx*ny*nz] = - mhd8all[idrs+6*nx*ny*nz];
00133 }}}
00134
00135
00136 double lonfirst,lonlast,carrtime;
00137 char *trecstr, *tobsstr;
00138 int carrot, cols, rows;
00139 char *mapcver, *mapbldv;
00140
00141 char strtmp[100];
00142 sprintf(strtmp,"%s[%s]",synostr,crdatestr);
00143 char *inQuery=strdup(strtmp);
00144 printf("now looking for synoptic map %s\n",inQuery);
00145 inRS = drms_open_records(drms_env, inQuery, &status);
00146 if (status || inRS->n == 0) {DIE("No input synoptic data found, so quit. Bye.");}
00147 int nrecs = inRS->n;
00148 if (nrecs > 1) {printf(" num. of data available is more than 1, %3d !!! Will use the first one anyway.\n",nrecs);}
00149 inRec = inRS->records[0];
00150 #if NEWMAP == 1
00151 inSeg = drms_segment_lookup(inRec,"Br");
00152 #else
00153 inSeg = drms_segment_lookupnum (inRec, 0);
00154 #endif
00155 cols = inSeg->axis[0];
00156 rows = inSeg->axis[1];
00157 lonfirst= drms_getkey_double(inRec,"LON_FRST",&status);
00158 lonlast = drms_getkey_double(inRec,"LON_LAST",&status);
00159 carrtime= drms_getkey_double(inRec,"CARRTIME",&status);
00160 printf(" LON_FRST of the syn.mag : %f\n",lonfirst);
00161 printf(" LON_LAST : %f\n",lonlast);
00162 printf(" CARRTIME : %f\n",carrtime);
00163 {
00164 TIME t_rec = drms_getkey_time(inRec,"T_REC",&status);
00165 TIME t_obs = drms_getkey_time(inRec,"T_OBS",&status);
00166 char timestr[26];
00167 sprint_time(timestr,t_rec,"TAI",0);
00168 trecstr=strdup(timestr);
00169 sprint_time(timestr,t_obs,"TAI",0);
00170 tobsstr=strdup(timestr);
00171 printf(" T_REC : %s\n",trecstr);
00172 printf(" T_OBS : %s\n",tobsstr);
00173 }
00174 carrot = drms_getkey_int(inRec,"CAR_ROT",&status);
00175 printf(" CAR_ROT : %d\n",carrot);
00176
00177
00178
00179
00180
00181
00182
00183 mapcver=drms_getkey_string(inRec,"CODEVER",&status);
00184 mapbldv=drms_getkey_string(inRec,"BLD_VERS",&status);
00185
00186
00187 printf(" Now open and create output at series %s\n",outstr);
00188 outRec = drms_create_record (drms_env, outstr, DRMS_PERMANENT, &status);
00189 if (!outRec) {fprintf (stderr, "Error creating record in series %s; abandoned\n",outstr);return 1;}
00190
00191
00192 drms_copykeys(outRec, inRec, 0, kDRMS_KeyClass_Explicit);
00193
00194
00195 drms_setkey_string(outRec,"MAP_BLDV" ,mapbldv);
00196 drms_setkey_string(outRec,"MAP_CVER" ,mapcver);
00197 #if NONDAILY == 1
00198 lonfirst = (double)(carrot-1)*360.0 + 360.0/((double)(nx))*0.5;
00199 lonlast = (double)(carrot )*360.0 - 360.0/((double)(nx))*0.5;
00200 #else
00201 lonfirst = lonfirst;
00202 lonlast = lonlast ;
00203 #endif
00204 printf(" LON_FRST of the MHD : %f\n",lonfirst);
00205 printf(" LON_LAST : %f\n",lonlast);
00206 drms_setkey_double(outRec,"LON_FRST", lonfirst);
00207 drms_setkey_double(outRec,"LON_LAST", lonlast);
00208
00209 {
00210 char timestr[26];
00211 TIME t_rec = drms_getkey_time(inRec,"DATE",&status);
00212 sprint_time(timestr,t_rec,"TAI",0);
00213 drms_setkey_string(outRec,"MAP_DATE" ,timestr);
00214 sprint_time(timestr,CURRENT_SYSTEM_TIME,"UTC",1);
00215 drms_setkey_string(outRec,"DATE" ,timestr);
00216 }
00217
00218 ddummy=((double)(nx))*0.5+0.5 ; drms_setkey_double(outRec,"CRPIX1",ddummy);
00219 ddummy=((double)(ny))*0.5+0.5 ; drms_setkey_double(outRec,"CRPIX2",ddummy);
00220 ddummy=((double)(nz))*0.5+0.5 ; drms_setkey_double(outRec,"CRPIX3",ddummy);
00221 ddummy=180.0+(double)(carrot-1)*360.0 ; drms_setkey_double(outRec,"CRVAL1",ddummy);
00222 ddummy=0.0 ; drms_setkey_double(outRec,"CRVAL2",ddummy);
00223 ddummy=(1.0+5.0)/2.0 ; drms_setkey_double(outRec,"CRVAL3",ddummy);
00224 ddummy=-360.0/((double)(nx)) ; drms_setkey_double(outRec,"CDELT1",ddummy);
00225 ddummy= 180.0/((double)(ny)) ; drms_setkey_double(outRec,"CDELT2",ddummy);
00226 ddummy= 4.000/((double)(nz)) ; drms_setkey_double(outRec,"CDELT3",ddummy);
00227 strdummy="degree" ; drms_setkey_string(outRec,"CUNIT1", strdummy);
00228 strdummy="degree" ; drms_setkey_string(outRec,"CUNIT2", strdummy);
00229 strdummy="solRad" ; drms_setkey_string(outRec,"CUNIT3", strdummy);
00230 strdummy="CRLN-CAR" ; drms_setkey_string(outRec,"CTYPE1", strdummy);
00231 strdummy="CRLT-CAR" ; drms_setkey_string(outRec,"CTYPE2", strdummy);
00232 strdummy="HECR" ; drms_setkey_string(outRec,"CTYPE3", strdummy);
00233 strdummy="3D-SPHERICAL" ; drms_setkey_string(outRec,"WCSNAME",strdummy);
00234 strdummy = mhdcorona_version() ; drms_setkey_string(outRec,"MHD_VER1",strdummy);
00235 #if NONDAILY == 1
00236 strdummy="v1.0, Jan. 10, 2014" ; drms_setkey_string(outRec,"MHD_VER2",strdummy);
00237 #else
00238 strdummy="v1.0, Dec. 10, 2013" ; drms_setkey_string(outRec,"MHD_VER2",strdummy);
00239 #endif
00240
00241
00242 {
00243 char *inputmapstr;
00244 char strtmp[100];
00245 #if NONDAILY == 1
00246 #if NEWMAP == 1
00247 sprintf(strtmp,"%s[%d]{Br}",synostr,carrot);
00248 #else
00249 sprintf(strtmp,"%s[%d]",synostr,carrot);
00250 #endif
00251 #else
00252 #if NEWMAP == 1
00253 sprintf(strtmp,"%s[%s]{Br}",synostr,trecstr);
00254 #else
00255 sprintf(strtmp,"%s[%s]",synostr,trecstr);
00256 #endif
00257 #endif
00258 inputmapstr=strdup(strtmp);
00259 drms_setkey_string(outRec,"INPUTMAP", inputmapstr);
00260 }
00261
00262 strdummy = "3D version of the code in ApJS (2005) vol.161, 480";
00263 drms_setkey_string(outRec,"MHDMODEL",strdummy);
00264 strdummy = "Polytropic, with specific heat ratio 1.05.";
00265 drms_setkey_string(outRec,"MHD_SET1", strdummy);
00266 strdummy = " ";
00267 if (ichrbnd == 0) {strdummy=" sub-Alfvenic boundary treatment: case O";}
00268 if (ichrbnd == 1) {strdummy=" sub-Alfvenic boundary treatment: case AB'";}
00269 if (ichrbnd == 6) {strdummy=" sub-Alfvenic boundary treatment: case A";}
00270 drms_setkey_string(outRec,"MHD_SET2", strdummy);
00271 strdummy = " ";
00272 drms_setkey_string(outRec,"MHD_SET3", strdummy);
00273 if (isphindx < 0)
00274 {
00275 strdummy = "PFSS with iterative Laplace solver";
00276 }
00277 else
00278 {
00279 char strtmp[100];
00280 sprintf(strtmp,"PFSS with %d-order spherical harmonics polynomial",isphindx);
00281 strdummy = strdup(strtmp);
00282 }
00283 drms_setkey_string(outRec,"MHDIBMAG", strdummy);
00284 drms_setkey_int(outRec,"MHDMGIDX", isphindx);
00285
00286 strdummy = " ";
00287 drms_setkey_string(outRec,"COMMENT", strdummy);
00288
00289
00290 drms_setkey_string(outRec,"BUNIT_000","1e8/cc");
00291 drms_setkey_string(outRec,"BUNIT_001","1e6K");
00292 drms_setkey_string(outRec,"BUNIT_002","km/s");
00293 drms_setkey_string(outRec,"BUNIT_003","km/s");
00294 drms_setkey_string(outRec,"BUNIT_004","km/s");
00295 drms_setkey_string(outRec,"BUNIT_005","Gauss");
00296 drms_setkey_string(outRec,"BUNIT_006","Gauss");
00297 drms_setkey_string(outRec,"BUNIT_007","Gauss");
00298 drms_setkey_string(outRec,"DSCRPT_000","number density");
00299 drms_setkey_string(outRec,"DSCRPT_001","temperature");
00300 drms_setkey_string(outRec,"DSCRPT_002","radial component of plasma flow");
00301 drms_setkey_string(outRec,"DSCRPT_003","latitudinal component of V (positive for northward)");
00302 drms_setkey_string(outRec,"DSCRPT_004","longitudinal component of V");
00303 drms_setkey_string(outRec,"DSCRPT_005","radial component of magnetic field");
00304 drms_setkey_string(outRec,"DSCRPT_006","latitudinal component of B (positive for northward)");
00305 drms_setkey_string(outRec,"DSCRPT_007","longitudinal component of B");
00306
00307
00308 char *Resname[] = {"N","T","Vr","Vt","Vp","Br","Bt","Bp"};
00309 int ivar;
00310 for(ivar = 0; ivar < 8; ivar++)
00311 {
00312 float *dat1;
00313 int axes[3];
00314 axes[0] = nx;
00315 axes[1] = ny;
00316 axes[2] = nz;
00317 dat1 = (float *)calloc(nx*ny*nz, sizeof(float));
00318 int ndatsize=nx*ny*nz;
00319 for(n = 0; n < ndatsize; n++){dat1[n] = mhd8all[(n+ndatsize*ivar)];}
00320 outArray = drms_array_create (DRMS_TYPE_FLOAT, 3, axes, dat1, &status);
00321 #if 0
00322 outArray->israw = 0;
00323 outArray->bzero = bzero[j];
00324 outArray->bscale = bscal[j];
00325 #endif
00326 outSeg = drms_segment_lookup (outRec, Resname[ivar]);
00327
00328 if (!outSeg)
00329 {
00330 printf("Error in setting data segment %s\n", Resname[ivar]);
00331 DIE(" bye \n")
00332 }
00333 else
00334 {
00335 set_statistics(outSeg, outArray, 1);
00336 printf("Now writing segment : %s\n", Resname[ivar]);
00337 if (drms_segment_write (outSeg, outArray, 0))
00338 {
00339 printf("Error in writing to %dth segment %s\n", ivar,Resname[ivar]);
00340 DIE(" bye \n")
00341 }
00342 }
00343 }
00344 printf("Done \n");
00345
00346
00347 drms_free_array(outArray);
00348 drms_close_record (outRec, DRMS_INSERT_RECORD);
00349 drms_close_records(inRS, DRMS_FREE_RECORD);
00350 return (DRMS_SUCCESS);
00351 }
00352
00353
00354
00355 char *mhdcorona_version(){return strdup("$Id: mhdtxt2jsoc_64cr.c,v 1.5 2014/08/09 01:52:12 keiji Exp $");}
00356
00357