Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015 import time
00016 import os
00017
00018
00019
00020
00021
00022
00023
00024 scriptmode = True
00025
00026
00027
00028
00029
00030
00031
00032 prefix='jupiter6cm.demo'
00033
00034 msfile = prefix + '.ms'
00035
00036
00037
00038
00039 calprefix = prefix + '.cal'
00040
00041 srcname = 'JUPITER'
00042 srcsplitms = calprefix + '.' + srcname + '.split.ms'
00043
00044
00045
00046
00047
00048
00049 imprefix = prefix + '.img'
00050
00051
00052 os.system('rm -rf '+imprefix+'*')
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067 clncell = [4.,4.]
00068
00069
00070
00071 clnalg = 'clark'
00072 clnmode = ''
00073
00074 clnmode = 'csclean'
00075 clnimsize = [288,288]
00076
00077
00078 clniter = 10000
00079
00080
00081
00082
00083
00084
00085 clnthreshold=0.05
00086
00087
00088
00089
00090 imname1 = imprefix + '.clean1'
00091 clnimage1 = imname1+'.image'
00092 clnmodel1 = imname1+'.model'
00093 clnresid1 = imname1+'.residual'
00094 clnmask1 = imname1+'.clean_interactive.mask'
00095
00096 imname2 = imprefix + '.clean2'
00097 clnimage2 = imname2+'.image'
00098 clnmodel2 = imname2+'.model'
00099 clnresid2 = imname2+'.residual'
00100 clnmask2 = imname2+'.clean_interactive.mask'
00101
00102 imname3 = imprefix + '.clean3'
00103 clnimage3 = imname3+'.image'
00104 clnmodel3 = imname3+'.model'
00105 clnresid3 = imname3+'.residual'
00106 clnmask3 = imname3+'.clean_interactive.mask'
00107
00108
00109
00110
00111
00112 calrefant = '11'
00113
00114
00115
00116
00117 selfcaltab1 = imprefix + '.selfcal1.gtable'
00118
00119 selfcaltab2 = imprefix + '.selfcal2.gtable'
00120 smoothcaltab2 = imprefix + '.smoothcal2.gtable'
00121
00122
00123
00124
00125
00126
00127
00128
00129 print '--Clearcal--'
00130 default('clearcal')
00131
00132 vis = srcsplitms
00133
00134 clearcal()
00135
00136 print "Reset calibration for MS "+vis
00137 print ""
00138
00139
00140
00141
00142
00143
00144
00145
00146 print '--Clean 1--'
00147 default('clean')
00148
00149
00150 vis = srcsplitms
00151
00152
00153 imagename = imname1
00154
00155 print "Output images will be prefixed with "+imname1
00156
00157
00158 mode = 'mfs'
00159 stokes = 'I'
00160
00161 print "Will be a single MFS continuum image"
00162
00163
00164 field = '*'
00165
00166
00167 spw = ''
00168
00169
00170 psfmode = clnalg
00171 imagermode = clnmode
00172
00173
00174 imsize = clnimsize
00175 cell = clncell
00176
00177
00178
00179
00180
00181 gain = 0.1
00182
00183
00184 niter = clniter
00185 threshold = clnthreshold
00186
00187
00188
00189
00190
00191
00192 weighting = 'briggs'
00193 robust = 0.5
00194
00195
00196 mask = ''
00197
00198
00199 interactive = True
00200
00201
00202 npercycle = 100
00203
00204 saveinputs('clean',imagename+'.clean.saved')
00205 clean()
00206
00207
00208
00209
00210
00211
00212
00213
00214
00215 print ""
00216 print "----------------------------------------------------"
00217 print "Clean"
00218 print "Final clean model is "+clnmodel1
00219 print "Final restored clean image is "+clnimage1
00220 print "The clean residual image is "+clnresid1
00221 print "Your final clean mask is "+clnmask1
00222
00223 print ""
00224 print "This is the final restored clean image in the viewer"
00225 print "Zoom in and set levels to see faint emission"
00226 print "Use rectangle drawing tool to box off source"
00227 print "Double-click inside to print statistics"
00228 print "Move box on-source and get the max"
00229 print "Calcualte DynRange = MAXon/RMSoff"
00230 print "I got 1.060/0.004 = 270"
00231 print "Still not as good as it can be - lets selfcal"
00232 print "Close viewer panel when done"
00233
00234
00235
00236
00237
00238 viewer(clnimage1,'image')
00239
00240
00241 if scriptmode:
00242 user_check=raw_input('Return to continue script\n')
00243
00244
00245
00246
00247
00248
00249
00250
00251
00252
00253
00254
00255
00256
00257
00258
00259
00260
00261
00262
00263
00264
00265
00266
00267
00268
00269
00270
00271
00272
00273
00274
00275 print '--Imstat--'
00276 default('imstat')
00277
00278 imagename = clnimage1
00279 on_statistics1 = imstat()
00280
00281
00282
00283 box = '216,1,287,72'
00284 off_statistics1 = imstat()
00285
00286
00287 thistest_immax=on_statistics1['max'][0]
00288 print ' Found : Max in image = ',thistest_immax
00289 thistest_imrms=off_statistics1['rms'][0]
00290 print ' Found : rms in image = ',thistest_imrms
00291 print ' Clean image Dynamic Range = ',thistest_immax/thistest_imrms
00292 print ''
00293
00294
00295
00296
00297
00298
00299
00300
00301
00302 print '--SelfCal 1--'
00303 default('gaincal')
00304
00305 vis = srcsplitms
00306
00307 print "Will self-cal using MODEL_DATA left in MS by clean"
00308
00309
00310 caltable = selfcaltab1
00311
00312 print "Will write gain table "+selfcaltab1
00313
00314
00315 selectdata = False
00316 gaincurve = False
00317 opacity = 0.0
00318
00319
00320 refant = calrefant
00321
00322
00323 gaintype = 'G'
00324 calmode = 'ap'
00325
00326
00327 solint = 30.0
00328 minsnr = 1.0
00329 print "Calibrating amplitudes and phases on 30s timescale"
00330
00331
00332 solnorm = False
00333
00334 gaincal()
00335
00336
00337
00338
00339
00340
00341 print '--PlotCal--'
00342 default('plotcal')
00343
00344 caltable = selfcaltab1
00345 multiplot = True
00346 yaxis = 'amp'
00347
00348 plotcal()
00349
00350 print ""
00351 print "-------------------------------------------------"
00352 print "Plotcal"
00353 print "Looking at amplitude in self-cal table "+caltable
00354
00355
00356 if scriptmode:
00357 user_check=raw_input('Return to continue script\n')
00358
00359 yaxis = 'phase'
00360
00361 plotcal()
00362
00363 print ""
00364 print "-------------------------------------------------"
00365 print "Plotcal"
00366 print "Looking at phases in self-cal table "+caltable
00367
00368
00369
00370 if scriptmode:
00371 user_check=raw_input('Return to continue script\n')
00372
00373
00374
00375
00376
00377
00378 print '--ApplyCal--'
00379 default('applycal')
00380
00381 vis = srcsplitms
00382
00383 print "Will apply self-cal table to over-write CORRECTED_DATA in MS"
00384
00385 gaintable = selfcaltab1
00386
00387 gaincurve = False
00388 opacity = 0.0
00389 field = ''
00390 spw = ''
00391 selectdata = False
00392
00393 calwt = True
00394
00395 applycal()
00396
00397
00398
00399
00400
00401 print '--Plotxy--'
00402 default('plotxy')
00403
00404 vis = srcsplitms
00405 selectdata = True
00406 field = 'JUPITER'
00407
00408 correlation = 'RR LL'
00409 xaxis = 'uvdist'
00410 yaxis = 'amp'
00411 datacolumn = 'corrected'
00412 multicolor = 'both'
00413
00414
00415 selectplot = True
00416 title = field+" "
00417
00418 iteration = ''
00419
00420 plotxy()
00421
00422 print ""
00423 print "-----------------------------------------------------"
00424 print "Plotting JUPITER self-corrected visibilities"
00425 print "Look for outliers, and you can flag them"
00426
00427
00428 if scriptmode:
00429 user_check=raw_input('Return to continue script\n')
00430
00431
00432
00433
00434
00435
00436 print '--Clean 2--'
00437 default('clean')
00438
00439 print "Now clean on self-calibrated data"
00440
00441 vis = srcsplitms
00442
00443 imagename = imname2
00444
00445 field = '*'
00446 spw = ''
00447 mode = 'mfs'
00448 gain = 0.1
00449
00450
00451 psfmode = clnalg
00452 imagermode = clnmode
00453 imsize = clnimsize
00454 cell = clncell
00455 niter = clniter
00456 threshold = clnthreshold
00457
00458 weighting = 'briggs'
00459 robust = 0.5
00460
00461 mask = ''
00462 interactive = True
00463 npercycle = 100
00464
00465 saveinputs('clean',imagename+'.clean.saved')
00466 clean()
00467
00468 print ""
00469 print "----------------------------------------------------"
00470 print "Clean"
00471 print "Final clean model is "+clnmodel2
00472 print "Final restored clean image is "+clnimage2
00473 print "The clean residual image is "+clnresid2
00474 print "Your final clean mask is "+clnmask2
00475
00476 print ""
00477 print "This is the final restored clean image in the viewer"
00478 print "Zoom in and set levels to see faint emission"
00479 print "Use rectangle drawing tool to box off source"
00480 print "Double-click inside to print statistics"
00481 print "Move box on-source and get the max"
00482 print "Calcualte DynRange = MAXon/RMSoff"
00483 print "This time I got 1.076 / 0.001389 = 775 (better)"
00484 print "Still not as good as it can be - lets selfcal again"
00485 print "Close viewer panel when done"
00486
00487
00488
00489
00490
00491 viewer(clnimage2,'image')
00492
00493
00494 if scriptmode:
00495 user_check=raw_input('Return to continue script\n')
00496
00497
00498
00499
00500
00501
00502
00503
00504
00505
00506
00507
00508
00509
00510
00511
00512
00513
00514
00515
00516
00517
00518
00519 print ""
00520 print "--------------------------------------------------"
00521 print "After this script is done you can continue on with"
00522 print "more self-cal, or try different cleaning options"
00523
00524
00525
00526
00527
00528
00529
00530 print '--Imstat (Cycle 2)--'
00531 default('imstat')
00532
00533 imagename = clnimage2
00534 on_statistics2 = imstat()
00535
00536
00537
00538 box = '216,1,287,72'
00539 off_statistics2 = imstat()
00540
00541
00542 thistest_immax=on_statistics2['max'][0]
00543 print ' Found : Max in image = ',thistest_immax
00544 thistest_imrms=off_statistics2['rms'][0]
00545 print ' Found : rms in image = ',thistest_imrms
00546 print ' Clean image Dynamic Range = ',thistest_immax/thistest_imrms
00547 print ''
00548
00549
00550
00551
00552
00553 print ""
00554 print ' Final Jupiter results '
00555 print ' ===================== '
00556 print ''
00557
00558 thistest_immax=on_statistics2['max'][0]
00559 oldtest_immax = 1.07732224464
00560 print ' Clean image ON-SRC max = ',thistest_immax
00561 print ' Previously found to be = ',oldtest_immax
00562 diff_immax = abs((oldtest_immax-thistest_immax)/oldtest_immax)
00563 print ' Difference (fractional) = ',diff_immax
00564
00565 print ''
00566 thistest_imrms=off_statistics2['rms'][0]
00567 oldtest_imrms = 0.0010449
00568 print ' Clean image OFF-SRC rms = ',thistest_imrms
00569 print ' Previously found to be = ',oldtest_imrms
00570 diff_imrms = abs((oldtest_imrms-thistest_imrms)/oldtest_imrms)
00571 print ' Difference (fractional) = ',diff_imrms
00572
00573 print ''
00574 print ' Final Clean image Dynamic Range = ',thistest_immax/thistest_imrms
00575 print ''
00576 print '--- Done ---'
00577
00578
00579