forked from ajstewart/PiLL
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcalibrator.parset
executable file
·851 lines (802 loc) · 63 KB
/
calibrator.parset
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
################################################################################################################################################################################################################################################################
## ##
## Beginning of calibrator pipeline ##
## ##
################################################################################################################################################################################################################################################################
### Steps to run
pipeline.steps = [listcal,listtemp,flagcal,listclock,listFR,listcolumn,listinst,parmdbclock,parmdbFR,fixFR,sourcedb,listsourcedbcal,predictcal,beamcal,lintocirc,smooth,smoothcal,makevds,findvds,globaldb,globaldbFR,globaldbampclock,h5parmFR,losotoFR,h5parmexpFR,listsolFR,match_files_calFR,beamcal,applyFR,smooth,smoothcal,globaldbCD,h5parmCD,listsoltableCD,losotoflag,losotoamp,losotoCD,h5parmexpCD,listsolCD,match_files_calCD,beamcal,applyCD,applyFR,smooth,smoothcal,globaldb2,h5parm2,listsoltable2,losotoflag,losotoclock,h5parmexpclock,h5parmmerge,losotomerge,h5parmexp]
################################################################################################################################################################################################################################################################
################################################################################################################################################################################################################################################################
### Step: 01
### --- List of calibrator files that will be processed in later steps
listcal.control.kind = plugin # plugin -> short, non-parallel step
listcal.control.type = createMapfile # generate a new mapfile
listcal.control.method = mapfile_from_folder # look for all files in a given directory
listcal.control.folder = {{ calibrator_directory }} # directory in which to look for the data
listcal.control.mapfile_dir = input.output.mapfile_dir # put the mapfile into the runtime directory
listcal.control.filename = listcal.mapfile # name of the generated mapfile
listcal.control.pattern = {{ calibrator_pattern }} # use only files that match this pattern
### Step: 02
### --- List of the single calibrator MS which is used as a template for making a skymodel
listtemp.control.kind = plugin # plugin -> short, non-parallel step
listtemp.control.type = createMapfile # generate a new mapfile
listtemp.control.method = mapfile_from_folder # look for all files in a given directory
listtemp.control.folder = {{ calibrator_directory }} # directory in which to look for the data
listtemp.control.mapfile_dir = input.output.mapfile_dir # put the mapfile into the runtime directory
listtemp.control.filename = listtemp.mapfile # name of the generated mapfile
listtemp.control.pattern = {{ calibrator_template }} # use only files that match this pattern
### Step: 03a
### --- Data preparation for the calibrator
flagcal.control.type = dppp
flagcal.control.max_per_node = {{ max_per_node_limit }}
flagcal.control.error_tolerance = {{ error_tolerance }}
flagcal.argument.numthreads = {{ max_dppp_threads }}
flagcal.argument.msin = listcal.output.mapfile
flagcal.argument.msin.baseline = [CR]S*&
flagcal.argument.msin.datacolumn = DATA
flagcal.argument.msout.datacolumn = DATA
flagcal.argument.msout.writefullresflag = False
flagcal.argument.steps = [filter,flagelevation,flag,avg,count]
flagcal.argument.filter.type = filter
flagcal.argument.filter.baseline = CS*&;CS*&RS*;RS*&{{ bad_stations }}
flagcal.argument.filter.remove = True
flagcal.argument.flagelevation.type = preflagger
flagcal.argument.flagelevation.elevation = {{ flag_elevation }}
flagcal.argument.flag.type = aoflagger
flagcal.argument.flag.keepstatistics = True
flagcal.argument.flag.strategy = {{ lofar_directory }}/share/rfistrategies/{{ rfistrategy }} ## better strategy for averaged data (also for LBA)
flagcal.argument.avg.type = averager
flagcal.argument.avg.freqstep = {{ average_freqstep }}
flagcal.argument.avg.timestep = {{ average_timestep }}
## Step: 03b
## --- Update mapfile for calibrator clock tables
listclock.control.kind = plugin
listclock.control.type = changeMapfile
listclock.control.mapfile_in = flagcal.output.mapfile
listclock.control.join_files = instrument-clock
listclock.control.newname = listclock.mapfile
### Step: 03c
### --- Update mapfile for calibrator FR tables
listFR.control.kind = plugin
listFR.control.type = changeMapfile
listFR.control.mapfile_in = flagcal.output.mapfile
listFR.control.join_files = instrument-fr
listFR.control.newname = listFR.mapfile
### Step: 03d
### --- Update mapfile for conversion to circular
listcolumn.control.kind = plugin
listcolumn.control.type = changeMapfile
listcolumn.control.mapfile_in = flagcal.output.mapfile
listcolumn.control.add_name = :CORRECTED_DATA
listcolumn.control.newname = listcolumn.mapfile
### Step: 03e
### --- List instrument table for calibrator field
listinst.control.kind = plugin
listinst.control.type = changeMapfile
listinst.control.mapfile_in = flagcal.output.mapfile
listinst.control.join_files = instrument
listinst.control.newname = listinst.mapfile
## Step: 04a
## --- Creation of fake-parmdbs (clock)
parmdbclock.control.type = python-calibrate-stand-alone
parmdbclock.control.error_tolerance = {{ error_tolerance }}
parmdbclock.control.max_per_node = {{ max_per_node }}
parmdbclock.argument.force = True # force replaceing of parmDB and skyDB
parmdbclock.argument.observation = flagcal.output.mapfile # run on files generated by flag_compress step
parmdbclock.argument.parmdb-name = instrument-clock
parmdbclock.argument.catalog = {{ skymodels }}/{{ calibrator }}.skymodel # which skymodel to use
parmdbclock.argument.numthreads = {{ max_per_node }}
parmdbclock.argument.Strategy.ChunkSize = 500
parmdbclock.argument.Strategy.Steps = [solve]
parmdbclock.argument.Step.solve.Operation = SOLVE
parmdbclock.argument.Step.solve.Model.Sources = [@MODEL_DATA]
parmdbclock.argument.Step.solve.Model.Cache.Enable = T
parmdbclock.argument.Step.solve.Model.Gain.Enable = T
parmdbclock.argument.Step.solve.Model.Clock.Enable = T
parmdbclock.argument.Step.solve.Solve.Parms = ["Gain:0:0:*", "Gain:1:1:*", "Clock:*"]
parmdbclock.argument.Step.solve.Solve.CellChunkSize = 500
parmdbclock.argument.Step.solve.Solve.PropagateSolutions = F
parmdbclock.argument.Step.solve.Solve.CellSize.Freq = 1
parmdbclock.argument.Step.solve.Solve.CellSize.Time = 1
parmdbclock.argument.Step.solve.Solve.Options.MaxIter = 1
### Step: 04b
### --- Creation of fake-parmdbs (Faraday Rotation)
parmdbFR.control.type = python-calibrate-stand-alone
parmdbFR.control.error_tolerance = {{ error_tolerance }}
parmdbFR.control.max_per_node = {{ max_per_node }}
parmdbFR.argument.force = True # force replaceing of parmDB and skyDB
parmdbFR.argument.observation = flagcal.output.mapfile # run on files generated by flag_compress step
parmdbFR.argument.parmdb-name = instrument-fr
parmdbFR.argument.catalog = {{ skymodels }}/{{ calibrator }}.skymodel # which skymodel to use
parmdbFR.argument.numthreads = {{ max_per_node }}
parmdbFR.argument.Strategy.ChunkSize = 500
parmdbFR.argument.Strategy.Steps = [solve]
parmdbFR.argument.Step.solve.Operation = SOLVE
parmdbFR.argument.Step.solve.Model.Sources = [@MODEL_DATA]
parmdbFR.argument.Step.solve.Model.Cache.Enable = T
parmdbFR.argument.Step.solve.Model.FaradayRotation.Enable = T
parmdbFR.argument.Step.solve.Solve.Parms = ["RotationMeasure:*"]
parmdbFR.argument.Step.solve.Solve.CellChunkSize = 500
parmdbFR.argument.Step.solve.Solve.PropagateSolutions = F
parmdbFR.argument.Step.solve.Solve.CellSize.Freq = 0
parmdbFR.argument.Step.solve.Solve.CellSize.Time = 1
parmdbFR.argument.Step.solve.Solve.Options.MaxIter = 1
### Step: 04c
### --- Fix entries in the NAMES subtable
fixFR.control.type = executable_args
fixFR.control.executable = {{ scripts }}/fixFR.bash
fixFR.control.error_tolerance = {{ error_tolerance }}
fixFR.argument.flags = [listFR.output.mapfile]
### Step: 05a
### --- Create skymodel for calibrator
sourcedb.control.type = setupsourcedb
sourcedb.control.cmdline.mapfile = listtemp.output.mapfile
sourcedb.control.skymodel = {{ skymodels }}/{{ calibrator }}.skymodel
### Step: 05b
### --- Expand skymodel mapfile to the amount of calibrator files
listsourcedbcal.control.kind = plugin
listsourcedbcal.control.type = expandMapfile
listsourcedbcal.control.mapfile_in = sourcedb.output.mapfile
listsourcedbcal.control.mapfile_ref = flagcal.output.mapfile
listsourcedbcal.control.mapfile_dir = input.output.mapfile_dir
listsourcedbcal.control.filename = listsourcedbcal.mapfile
### Step: 06
### --- Predict calibrator model
predictcal.control.type = dppp
predictcal.control.inplace = True
predictcal.control.max_per_node = {{ max_per_node_limit }}
predictcal.control.error_tolerance = {{ error_tolerance }}
predictcal.argument.numthreads = {{ max_dppp_threads }}
predictcal.control.mapfiles_in = [flagcal.output.mapfile,listsourcedbcal.output.mapfile]
predictcal.control.inputkeys = [infiles,sourcedb]
predictcal.argument.msin = infiles
predictcal.argument.msin.datacolumn = DATA
predictcal.argument.msin.baseline = [CR]S*&
predictcal.argument.msout.datacolumn = MODEL_DATA
predictcal.argument.steps = [predict]
predictcal.argument.predict.type = predict
predictcal.argument.predict.sourcedb = sourcedb
predictcal.argument.predict.sources = []
predictcal.argument.predict.usebeammodel = True
predictcal.argument.predict.usechannelfreq = False
predictcal.argument.predict.beammode = array_factor
### Step: 07
### --- Beam correction
beamcal.control.type = dppp
beamcal.control.inplace = True
beamcal.control.max_per_node = {{ max_per_node_limit }}
beamcal.control.error_tolerance = {{ error_tolerance }}
beamcal.argument.numthreads = {{ max_dppp_threads }}
beamcal.argument.msin = flagcal.output.mapfile
beamcal.argument.msin.datacolumn = DATA
beamcal.argument.msout.datacolumn = CORRECTED_DATA
beamcal.argument.steps = [applybeam]
beamcal.argument.applybeam.type = applybeam
beamcal.argument.applybeam.invert = True
beamcal.argument.applybeam.usechannelfreq = False
### Step: 08
### --- Convert to circular
lintocirc.control.type = executable_args
lintocirc.control.max_per_node = {{ max_per_node_limit }}
lintocirc.control.error_tolerance = {{ error_tolerance }}
lintocirc.control.executable = {{ scripts }}/mslin2circ.py
lintocirc.argument.flags = [-i,listcolumn.output.mapfile,-o,listcolumn.output.mapfile]
### Step: 09
### --- Smooth the data (baseline-based)
smooth.control.type = executable_args
smooth.control.max_per_node = 1
smooth.control.error_tolerance = {{ error_tolerance }}
smooth.control.executable = {{ scripts }}/BLsmooth.py
smooth.argument.flags = [-r,-i,CORRECTED_DATA,-o,SMOOTHED_DATA,flagcal.output.mapfile]
### Step: 10
### --- Calibrate smoothed data
smoothcal.control.type = dppp
smoothcal.control.inplace = True
smoothcal.control.error_tolerance = {{ error_tolerance }}
smoothcal.control.max_per_node = {{ max_per_node_limit }}
smoothcal.control.mapfiles_in = [flagcal.output.mapfile,listinst.output.mapfile]
smoothcal.control.inputkeys = [infiles,parmdbs]
smoothcal.argument.numthreads = {{ max_dppp_threads }}
smoothcal.argument.msin = infiles
smoothcal.argument.msin.datacolumn = SMOOTHED_DATA
smoothcal.argument.msin.baseline = [CR]S*&
smoothcal.argument.msout.datacolumn = CORRECTED_DATA
smoothcal.argument.steps = [filter,gaincal]
smoothcal.argument.filter.blrange = [3000,1e30]
smoothcal.argument.gaincal.type = gaincal
smoothcal.argument.gaincal.parmdb = parmdbs
smoothcal.argument.gaincal.caltype = diagonal
smoothcal.argument.gaincal.maxiter = 500
smoothcal.argument.gaincal.nchan = 1
smoothcal.argument.gaincal.solint = 1
smoothcal.argument.gaincal.propagatesolutions = False
smoothcal.argument.gaincal.usemodelcolumn = True
### Step: 11a
### --- Creating VDS files
makevds.control.type = vdsmaker
makevds.control.cmdline.inmap = flagcal.output.mapfile
makevds.control.unlink = True
### Step: 11b
### --- Creating mapfile for the VDS files
findvds.control.kind = plugin
findvds.control.type = createMapfile
findvds.control.method = mapfile_from_folder
findvds.control.folder = {{ job_directory }}/vds
findvds.control.mapfile_dir = input.output.mapfile_dir
findvds.control.filename = findvds.mapfile
### Step: 12a
### --- Create globaldb out of the VDS files for the instrument tables
globaldb.control.type = executable_args
globaldb.control.executable = {{ losoto_directory }}/bin/parmdb_collector.py
globaldb.argument.flags = [-v,-d,findvds.output.mapfile,-g,outputkey]
### Step: 12b
### --- Create globaldb out of the VDS files for the instrument-fr tables
globaldbFR.control.type = executable_args
globaldbFR.control.executable = {{ losoto_directory }}/bin/parmdb_collector.py
globaldbFR.argument.flags = [-v,-d,findvds.output.mapfile,-p,instrument-fr,-g,outputkey]
### Step: 12c
### --- Create globaldb out of the VDS files for the instrument-clock tables
globaldbampclock.control.type = executable_args
globaldbampclock.control.executable = {{ losoto_directory }}/bin/parmdb_collector.py
globaldbampclock.argument.flags = [-v,-d,findvds.output.mapfile,-p,instrument-clock,-g,outputkey]
### Step: 13a
### --- Import globaldb to h5parm
h5parmFR.control.type = executable_args
h5parmFR.control.executable = {{ losoto_directory }}/bin/H5parm_importer.py
h5parmFR.argument.flags = [-v,outputkey,globaldb.output.mapfile]
### Step: 13b
### --- Running losoto to plot, flag and do the Farady Rotation extraction
losotoFR.control.type = executable_args
losotoFR.control.executable = {{ losoto_directory }}/bin/losoto
losotoFR.control.parsetasfile = True
losotoFR.control.args_format = losoto
losotoFR.argument.flags = [-v,h5parmFR.output.mapfile]
losotoFR.argument.LoSoTo.Steps = [duplicateBkp, plotPi, faraday, plotFR, residuals, plotPr]
losotoFR.argument.LoSoTo.Solset = [sol000]
losotoFR.argument.LoSoTo.Soltab = []
losotoFR.argument.LoSoTo.SolType = []
losotoFR.argument.LoSoTo.ant = []
losotoFR.argument.LoSoTo.pol = [XX, YY]
losotoFR.argument.LoSoTo.dir = []
losotoFR.argument.LoSoTo.Ncpu = {{ max_per_node }}
losotoFR.argument.LoSoTo.Steps.duplicateBkp.Operation = DUPLICATE
losotoFR.argument.LoSoTo.Steps.duplicateBkp.InTable = sol000/phase000
losotoFR.argument.LoSoTo.Steps.duplicateBkp.OutTable = sol000/phaseOrig000
losotoFR.argument.LoSoTo.Steps.plotPi.Operation = PLOT
losotoFR.argument.LoSoTo.Steps.plotPi.Soltab = [sol000/phase000]
losotoFR.argument.LoSoTo.Steps.plotPi.Axes = [time,freq]
losotoFR.argument.LoSoTo.Steps.plotPi.TableAxis = ant
losotoFR.argument.LoSoTo.Steps.plotPi.DiffAxis = pol
losotoFR.argument.LoSoTo.Steps.plotPi.PlotFlag = True
losotoFR.argument.LoSoTo.Steps.plotPi.Prefix = plots-fr/ph-rot_
losotoFR.argument.LoSoTo.Steps.plotPi.Reference = {{ reference_station }}
losotoFR.argument.LoSoTo.Steps.plotPi.MinMax = [-3.14,3.14]
losotoFR.argument.LoSoTo.Steps.faraday.Operation = FARADAY
losotoFR.argument.LoSoTo.Steps.faraday.Soltab = [sol000/phase000]
losotoFR.argument.LoSoTo.Steps.faraday.RefAnt = {{ reference_station }}
losotoFR.argument.LoSoTo.Steps.plotFR.Operation = PLOT
losotoFR.argument.LoSoTo.Steps.plotFR.Soltab = [sol000/rotationmeasure000]
losotoFR.argument.LoSoTo.Steps.plotFR.Axes = [time]
losotoFR.argument.LoSoTo.Steps.plotFR.TableAxis = ant
losotoFR.argument.LoSoTo.Steps.plotFR.Prefix = plots-fr/fr
losotoFR.argument.LoSoTo.Steps.residuals.Operation = RESIDUALS
losotoFR.argument.LoSoTo.Steps.residuals.Soltab = [sol000/phase000]
losotoFR.argument.LoSoTo.Steps.residuals.Sub = [sol000/rotationmeasure000]
losotoFR.argument.LoSoTo.Steps.plotPr.Operation = PLOT
losotoFR.argument.LoSoTo.Steps.plotPr.Soltab = [sol000/phase000]
losotoFR.argument.LoSoTo.Steps.plotPr.Axes = [time,freq]
losotoFR.argument.LoSoTo.Steps.plotPr.TableAxis = ant
losotoFR.argument.LoSoTo.Steps.plotPr.DiffAxis = pol
losotoFR.argument.LoSoTo.Steps.plotPr.PlotFlag = True
losotoFR.argument.LoSoTo.Steps.plotPr.Prefix = plots-fr/phRes-rot_
losotoFR.argument.LoSoTo.Steps.plotPr.Reference = {{ reference_station }}
losotoFR.argument.LoSoTo.Steps.plotPr.MinMax = [-3.14,3.14]
### Step: 13c
### --- Export rotationmeasure from h5parm to globaldb-fr
h5parmexpFR.control.type = executable_args
h5parmexpFR.control.executable = {{ scripts }}/H5parm_exporter.py
h5parmexpFR.argument.flags = [-v,-c,-t,rotationmeasure000,h5parmFR.output.mapfile,globaldbFR.output.mapfile]
### Step: 13d
### --- List new solution tables
listsolFR.control.kind = plugin # plugin -> short, non-parallel step
listsolFR.control.type = createMapfile # generate a new mapfile
listsolFR.control.method = mapfile_from_folder # look for all files in a given directory
listsolFR.control.folder = {{ job_directory }}/{{ job_name }}.calibrator-globaldbFR
listsolFR.control.mapfile_dir = input.output.mapfile_dir # put the mapfile into the runtime directory
listsolFR.control.filename = listsolFR.mapfile # name of the generated mapfile
listsolFR.control.pattern = sol000_instrument*
### Step: 13e
# Find appropriate MSs to match with phase solutions (which are probably from a group)
# This is a custom plugin. It is matching the frequency information of the parmdbs with the corresponding measurement sets
match_files_calFR.control.kind = plugin
match_files_calFR.control.type = FindCorrespondingMSX
match_files_calFR.control.mapfile_dir = input.output.mapfile_dir
match_files_calFR.control.filename = match_files_calFR.mapfile
match_files_calFR.control.mapfile_grpd = listsolFR.output.mapfile
match_files_calFR.control.mapfile_ms = flagcal.output.mapfile
### Step: 14
### --- Apply FaradyRotation correction
applyFR.control.type = dppp
applyFR.control.inplace = True
applyFR.control.error_tolerance = {{ error_tolerance }}
applyFR.control.max_per_node = {{ max_per_node_limit }}
applyFR.control.mapfiles_in = [match_files_calFR.output.mapfile,match_files_calFR.output.parmdbs]
applyFR.control.inputkeys = [infiles,parmdbs]
applyFR.argument.numthreads = {{ max_dppp_threads }}
applyFR.argument.msin = infiles
applyFR.argument.msin.datacolumn = CORRECTED_DATA
applyFR.argument.msout.datacolumn = CORRECTED_DATA
applyFR.argument.steps = [correct]
applyFR.argument.correct.type = correct
applyFR.argument.correct.parmdb = parmdbs
applyFR.argument.correct.correction = RotationMeasure
### Step: 15
### --- Create globaldb out of the VDS files for the instrument tables
globaldbCD.control.type = executable_args
globaldbCD.control.executable = {{ losoto_directory }}/bin/parmdb_collector.py
globaldbCD.argument.flags = [-v,-d,findvds.output.mapfile,-g,outputkey]
### Step: 16a
### --- Import globaldb to h5parm
h5parmCD.control.type = executable_args
h5parmCD.control.executable = {{ losoto_directory }}/bin/H5parm_importer.py
h5parmCD.argument.flags = [-v,outputkey,globaldbCD.output.mapfile]
### Step: 16b
### --- Update mapfile for conversion to circular
listsoltableCD.control.kind = plugin
listsoltableCD.control.type = changeMapfile
listsoltableCD.control.mapfile_in = h5parmCD.output.mapfile
listsoltableCD.control.add_name = :sol000
listsoltableCD.control.newname = listsoltableCD.mapfile
### Step: 16c
### --- Running losoto for plotting, flagging and deriving the cross delays
losotoflag.control.type = executable_args
losotoflag.control.executable = {{ losoto_directory }}/bin/losoto
losotoflag.control.parsetasfile = True
losotoflag.control.args_format = losoto
losotoflag.argument.flags = [-v,h5parmCD.output.mapfile]
losotoflag.argument.LoSoTo.Steps = [plotA1, flag, flagextend, plotA2, merge]
losotoflag.argument.LoSoTo.Solset = [sol000]
losotoflag.argument.LoSoTo.Soltab = []
losotoflag.argument.LoSoTo.SolType = []
losotoflag.argument.LoSoTo.ant = []
losotoflag.argument.LoSoTo.pol = [XX, YY]
losotoflag.argument.LoSoTo.dir = []
losotoflag.argument.LoSoTo.Ncpu = {{ max_per_node }}
losotoflag.argument.LoSoTo.Steps.plotA1.Operation = PLOT
losotoflag.argument.LoSoTo.Steps.plotA1.Soltab = [sol000/amplitude000]
losotoflag.argument.LoSoTo.Steps.plotA1.Axes = [time,freq]
losotoflag.argument.LoSoTo.Steps.plotA1.TableAxis = ant
losotoflag.argument.LoSoTo.Steps.plotA1.PlotFlag = True
losotoflag.argument.LoSoTo.Steps.plotA1.Prefix = plots-cd/ampBF_
losotoflag.argument.LoSoTo.Steps.flag.Operation = FLAG
losotoflag.argument.LoSoTo.Steps.flag.Soltab = [sol000/amplitude000]
losotoflag.argument.LoSoTo.Steps.flag.Axes = [time]
losotoflag.argument.LoSoTo.Steps.flag.MaxCycles = 1
losotoflag.argument.LoSoTo.Steps.flag.MaxRms = 5
losotoflag.argument.LoSoTo.Steps.flag.Order = [100]
losotoflag.argument.LoSoTo.Steps.flag.Replce = False
losotoflag.argument.LoSoTo.Steps.flag.PreFlagZeros = False
losotoflag.argument.LoSoTo.Steps.flag.Mode = smooth
losotoflag.argument.LoSoTo.Steps.flagextend.Operation = FLAGEXTEND
losotoflag.argument.LoSoTo.Steps.flagextend.Soltab = [sol000/amplitude000]
losotoflag.argument.LoSoTo.Steps.flagextend.Axes = [freq,time]
losotoflag.argument.LoSoTo.Steps.flagextend.Percent = 50
losotoflag.argument.LoSoTo.Steps.flagextend.Size = [50,100]
losotoflag.argument.LoSoTo.Steps.flagextend.Cycles = 3
losotoflag.argument.LoSoTo.Steps.plotA2.Operation = PLOT
losotoflag.argument.LoSoTo.Steps.plotA2.Soltab = [sol000/amplitude000]
losotoflag.argument.LoSoTo.Steps.plotA2.Axes = [time,freq]
losotoflag.argument.LoSoTo.Steps.plotA2.TableAxis = ant
losotoflag.argument.LoSoTo.Steps.plotA2.PlotFlag = True
losotoflag.argument.LoSoTo.Steps.plotA2.Prefix = plots-cd/ampAF_
losotoflag.argument.LoSoTo.Steps.merge.Operation = REWEIGHT
losotoflag.argument.LoSoTo.Steps.merge.Soltab = [sol000/phase000]
losotoflag.argument.LoSoTo.Steps.merge.MergeFromSoltab = sol000/amplitude000
### Step: 16d
### --- Running losoto for plotting, flagging and deriving the cross delays
losotoamp.control.type = executable_args
losotoamp.control.executable = {{ losoto_directory }}/bin/losoto
losotoamp.control.parsetasfile = True
losotoamp.control.args_format = losoto
losotoamp.argument.flags = [-v,h5parmCD.output.mapfile]
losotoamp.argument.LoSoTo.Steps = [duplicateAbkp, plotAi1, plotAi2, plotAi3, duplicateA, smoothA, plotAs, plotAs2, residualA, plotAr1, plotAr2, plotAr3]
losotoamp.argument.LoSoTo.Solset = [sol000]
losotoamp.argument.LoSoTo.Soltab = []
losotoamp.argument.LoSoTo.SolType = []
losotoamp.argument.LoSoTo.ant = []
losotoamp.argument.LoSoTo.pol = []
losotoamp.argument.LoSoTo.dir = []
losotoamp.argument.LoSoTo.Ncpu = {{ max_per_node }}
losotoamp.argument.LoSoTo.Steps.duplicateAbkp.Operation = DUPLICATE
losotoamp.argument.LoSoTo.Steps.duplicateAbkp.InTable = sol000/amplitude000
losotoamp.argument.LoSoTo.Steps.duplicateAbkp.OutTable = sol000/amplitudeOrig000
losotoamp.argument.LoSoTo.Steps.plotAi1.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAi1.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.plotAi1.freq.minmax = [0,300e6,100]
losotoamp.argument.LoSoTo.Steps.plotAi1.Axes = time
losotoamp.argument.LoSoTo.Steps.plotAi1.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAi1.ColorAxis = pol
losotoamp.argument.LoSoTo.Steps.plotAi1.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAi1.Prefix = plots-amp/amp_
losotoamp.argument.LoSoTo.Steps.plotAi1.Columns = 4
losotoamp.argument.LoSoTo.Steps.plotAi1.FigSize = [20,20]
losotoamp.argument.LoSoTo.Steps.plotAi2.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAi2.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.plotAi2.time.minmax = [0,1e20,500]
losotoamp.argument.LoSoTo.Steps.plotAi2.Axes = freq
losotoamp.argument.LoSoTo.Steps.plotAi2.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAi2.ColorAxis = pol
losotoamp.argument.LoSoTo.Steps.plotAi2.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAi2.Prefix = plots-amp/amp_
losotoamp.argument.LoSoTo.Steps.plotAi3.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAi3.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.plotAi3.Axes = [time,freq]
losotoamp.argument.LoSoTo.Steps.plotAi3.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAi3.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAi3.Prefix = plots-amp/amp_
losotoamp.argument.LoSoTo.Steps.duplicateA.Operation = DUPLICATE
losotoamp.argument.LoSoTo.Steps.duplicateA.InTable = sol000/amplitude000
losotoamp.argument.LoSoTo.Steps.duplicateA.OutTable = sol000/amplitudeSmooth000
losotoamp.argument.LoSoTo.Steps.smoothA.Operation = SMOOTH
losotoamp.argument.LoSoTo.Steps.smoothA.Soltab = [sol000/amplitudeSmooth000]
losotoamp.argument.LoSoTo.Steps.smoothA.Axes = [time]
losotoamp.argument.LoSoTo.Steps.smoothA.Mode = median
losotoamp.argument.LoSoTo.Steps.plotAs.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAs.Soltab = [sol000/amplitudeSmooth000]
losotoamp.argument.LoSoTo.Steps.plotAs.Axes = [time,freq]
losotoamp.argument.LoSoTo.Steps.plotAs.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAs.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAs.Prefix = plots-amp/ampSmooth_
losotoamp.argument.LoSoTo.Steps.plotAs2.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAs2.Soltab = [sol000/amplitudeSmooth000]
losotoamp.argument.LoSoTo.Steps.plotAs2.Axes = freq
losotoamp.argument.LoSoTo.Steps.plotAs2.time.minmax = [0,1e20,50000]
losotoamp.argument.LoSoTo.Steps.plotAs2.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAs2.ColorAxis = pol
losotoamp.argument.LoSoTo.Steps.plotAs2.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAs2.Prefix = plots-amp/ampSmooth_
losotoamp.argument.LoSoTo.Steps.residualA.Operation = RESIDUALS
losotoamp.argument.LoSoTo.Steps.residualA.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.residualA.Sub = [sol000/amplitudeSmooth000]
losotoamp.argument.LoSoTo.Steps.residualA.Ratio = True
losotoamp.argument.LoSoTo.Steps.plotAr1.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAr1.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.plotAr1.freq.minmax = [0,300e6,100]
losotoamp.argument.LoSoTo.Steps.plotAr1.Axes = time
losotoamp.argument.LoSoTo.Steps.plotAr1.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAr1.ColorAxis = pol
losotoamp.argument.LoSoTo.Steps.plotAr1.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAr1.Prefix = plots-amp/ampRes_
losotoamp.argument.LoSoTo.Steps.plotAr1.Columns = 4
losotoamp.argument.LoSoTo.Steps.plotAr1.FigSize = [20,20]
losotoamp.argument.LoSoTo.Steps.plotAr1.MinMax = [-1,1]
losotoamp.argument.LoSoTo.Steps.plotAr2.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAr2.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.plotAr2.time.minmax = [0,1e20,500]
losotoamp.argument.LoSoTo.Steps.plotAr2.Axes = freq
losotoamp.argument.LoSoTo.Steps.plotAr2.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAr2.ColorAxis = pol
losotoamp.argument.LoSoTo.Steps.plotAr2.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAr2.Prefix = plots-amp/ampRes_
losotoamp.argument.LoSoTo.Steps.plotAr2.MinMax = [-1,1]
losotoamp.argument.LoSoTo.Steps.plotAr3.Operation = PLOT
losotoamp.argument.LoSoTo.Steps.plotAr3.Soltab = [sol000/amplitude000]
losotoamp.argument.LoSoTo.Steps.plotAr3.Axes = [time,freq]
losotoamp.argument.LoSoTo.Steps.plotAr3.TableAxis = ant
losotoamp.argument.LoSoTo.Steps.plotAr3.PlotFlag = True
losotoamp.argument.LoSoTo.Steps.plotAr3.Prefix = plots-amp/ampRes_
losotoamp.argument.LoSoTo.Steps.plotAr3.MinMax = [-1,1]
### Step: 16e
### --- Running losoto for plotting, flagging and deriving the cross delays
losotoCD.control.type = executable_args
losotoCD.control.executable = {{ losoto_directory }}/bin/losoto
losotoCD.control.parsetasfile = True
losotoCD.control.args_format = losoto
losotoCD.argument.flags = [-v,h5parmCD.output.mapfile]
losotoCD.argument.LoSoTo.Steps = [duplicateBkp, plotPi, plotPi2, crossdelay, plotCD, residuals, plotPr, plotPr2]
losotoCD.argument.LoSoTo.Solset = [sol000]
losotoCD.argument.LoSoTo.Soltab = []
losotoCD.argument.LoSoTo.SolType = []
losotoCD.argument.LoSoTo.ant = []
losotoCD.argument.LoSoTo.pol = [XX, YY]
losotoCD.argument.LoSoTo.dir = []
losotoCD.argument.LoSoTo.Ncpu = {{ max_per_node }}
losotoCD.argument.LoSoTo.Steps.duplicateBkp.Operation = DUPLICATE
losotoCD.argument.LoSoTo.Steps.duplicateBkp.InTable = sol000/phase000
losotoCD.argument.LoSoTo.Steps.duplicateBkp.OutTable = sol000/phaseOrig000
losotoCD.argument.LoSoTo.Steps.plotPi.Operation = PLOT
losotoCD.argument.LoSoTo.Steps.plotPi.Soltab = [sol000/phase000]
losotoCD.argument.LoSoTo.Steps.plotPi.Axes = [time,freq]
losotoCD.argument.LoSoTo.Steps.plotPi.TableAxis = ant
losotoCD.argument.LoSoTo.Steps.plotPi.DiffAxis = pol
losotoCD.argument.LoSoTo.Steps.plotPi.PlotFlag = True
losotoCD.argument.LoSoTo.Steps.plotPi.Prefix = plots-cd/ph-init_
losotoCD.argument.LoSoTo.Steps.plotPi.Reference = {{ reference_station }}
losotoCD.argument.LoSoTo.Steps.plotPi.MinMax = [-1,+1]
losotoCD.argument.LoSoTo.Steps.plotPi2.Operation = PLOT
losotoCD.argument.LoSoTo.Steps.plotPi2.Soltab = [sol000/phase000]
losotoCD.argument.LoSoTo.Steps.plotPi2.time.minmax = [0,1e20,500]
losotoCD.argument.LoSoTo.Steps.plotPi2.Axes = freq
losotoCD.argument.LoSoTo.Steps.plotPi2.TableAxis = ant
losotoCD.argument.LoSoTo.Steps.plotPi2.ColorAxis = pol
losotoCD.argument.LoSoTo.Steps.plotPi2.PlotFlag = True
losotoCD.argument.LoSoTo.Steps.plotPi2.Prefix = plots-cd/ph-init_
losotoCD.argument.LoSoTo.Steps.plotPi2.Reference = {{ reference_station }}
losotoCD.argument.LoSoTo.Steps.plotPi2.MinMax = [-3.14,3.14]
losotoCD.argument.LoSoTo.Steps.crossdelay.Soltab = [sol000/phase000]
losotoCD.argument.LoSoTo.Steps.crossdelay.Operation = CROSSDELAY
losotoCD.argument.LoSoTo.Steps.crossdelay.OutTable = crossdelay
losotoCD.argument.LoSoTo.Steps.crossdelay.Smooth = 201
losotoCD.argument.LoSoTo.Steps.crossdelay.Reference = {{ reference_station }}
losotoCD.argument.LoSoTo.Steps.plotCD.Operation = PLOT
losotoCD.argument.LoSoTo.Steps.plotCD.Soltab = [sol000/crossdelay]
losotoCD.argument.LoSoTo.Steps.plotCD.Axes = [time,freq]
losotoCD.argument.LoSoTo.Steps.plotCD.TableAxis = ant
losotoCD.argument.LoSoTo.Steps.plotCD.DiffAxis = pol
losotoCD.argument.LoSoTo.Steps.plotCD.PlotFlag = True
losotoCD.argument.LoSoTo.Steps.plotCD.Prefix = plots-cd/ph-CD_
losotoCD.argument.LoSoTo.Steps.plotCD.Reference = {{ reference_station }}
losotoCD.argument.LoSoTo.Steps.plotCD.MinMax = [-1,+1]
losotoCD.argument.LoSoTo.Steps.residuals.Operation = RESIDUALS
losotoCD.argument.LoSoTo.Steps.residuals.Soltab = [sol000/phase000]
losotoCD.argument.LoSoTo.Steps.residuals.Sub = [sol000/crossdelay]
losotoCD.argument.LoSoTo.Steps.plotPr.Operation = PLOT
losotoCD.argument.LoSoTo.Steps.plotPr.Soltab = [sol000/phase000]
losotoCD.argument.LoSoTo.Steps.plotPr.Axes = [time,freq]
losotoCD.argument.LoSoTo.Steps.plotPr.TableAxis = ant
losotoCD.argument.LoSoTo.Steps.plotPr.DiffAxis = pol
losotoCD.argument.LoSoTo.Steps.plotPr.PlotFlag = True
losotoCD.argument.LoSoTo.Steps.plotPr.Prefix = plots-cd/ph-res_
losotoCD.argument.LoSoTo.Steps.plotPr.Reference = {{ reference_station }}
losotoCD.argument.LoSoTo.Steps.plotPr.MinMax = [-1,+1]
losotoCD.argument.LoSoTo.Steps.plotPr2.Operation = PLOT
losotoCD.argument.LoSoTo.Steps.plotPr2.Soltab = [sol000/phase000]
losotoCD.argument.LoSoTo.Steps.plotPr2.time.minmax = [0,1e20,500]
losotoCD.argument.LoSoTo.Steps.plotPr2.Axes = freq
losotoCD.argument.LoSoTo.Steps.plotPr2.TableAxis = ant
losotoCD.argument.LoSoTo.Steps.plotPr2.ColorAxis = pol
losotoCD.argument.LoSoTo.Steps.plotPr2.PlotFlag = True
losotoCD.argument.LoSoTo.Steps.plotPr2.Prefix = plots-cd/ph-res_
losotoCD.argument.LoSoTo.Steps.plotPr2.Reference = {{ reference_station }}
losotoCD.argument.LoSoTo.Steps.plotPr2.MinMax = [-3.14,3.14]
### Step: 16f
### --- Export cross-delays to globaldb2
h5parmexpCD.control.type = executable_args
h5parmexpCD.control.executable = {{ scripts }}/H5parm_exporter.py
h5parmexpCD.argument.flags = [-v,-c,-t,"amplitudeSmooth000;crossdelay",h5parmCD.output.mapfile,globaldbCD.output.mapfile]
### Step: 16g
### --- List new solution tables
listsolCD.control.kind = plugin # plugin -> short, non-parallel step
listsolCD.control.type = createMapfile # generate a new mapfile
listsolCD.control.method = mapfile_from_folder # look for all files in a given directory
listsolCD.control.folder = {{ job_directory }}/{{ job_name }}.calibrator-globaldbCD # directory in which to look for the data
listsolCD.control.mapfile_dir = input.output.mapfile_dir # put the mapfile into the runtime directory
listsolCD.control.filename = listsolCD.mapfile # name of the generated mapfile
listsolCD.control.pattern = sol000_instrument*
### Step: 16h
# Find appropriate MSs to match with phase solutions (which are probably from a group)
# This is a custom plugin. It is matching the frequency information of the parmdbs with the corresponding measurement sets
match_files_calCD.control.kind = plugin
match_files_calCD.control.type = FindCorrespondingMSX
match_files_calCD.control.mapfile_dir = input.output.mapfile_dir
match_files_calCD.control.filename = match_files_calCD.mapfile
match_files_calCD.control.mapfile_grpd = listsolCD.output.mapfile
match_files_calCD.control.mapfile_ms = flagcal.output.mapfile
### Step: 17
### --- Apply CrossDelay correction
applyCD.control.type = dppp
applyCD.control.inplace = True
applyCD.control.error_tolerance = {{ error_tolerance }}
applyCD.control.max_per_node = {{ max_per_node_limit }}
applyCD.control.mapfiles_in = [match_files_calCD.output.mapfile,match_files_calCD.output.parmdbs]
applyCD.control.inputkeys = [infiles,parmdbs]
applyCD.argument.numthreads = {{ max_dppp_threads }}
applyCD.argument.msin = infiles
applyCD.argument.msin.datacolumn = DATA
applyCD.argument.msout.datacolumn = CORRECTED_DATA
applyCD.argument.steps = [correct,applybeam]
applyCD.argument.correct.type = correct
applyCD.argument.correct.parmdb = parmdbs
applyCD.argument.correct.correction = gain
applyCD.argument.correct.updateweights = True
applyCD.argument.applybeam.type = applybeam
applyCD.argument.applybeam.invert = True
applyCD.argument.applybeam.usechannelfreq = False
applyCD.argument.applybeam.updateweights = True
### Step: 18
### --- Create globaldb out of the VDS files for the instrument tables
globaldb2.control.type = executable_args
globaldb2.control.executable = {{ losoto_directory }}/bin/parmdb_collector.py
globaldb2.argument.flags = [-v,-d,findvds.output.mapfile,-g,outputkey]
### Step: 19a
### --- Import globaldb to h5parm
h5parm2.control.type = executable_args
h5parm2.control.executable = {{ losoto_directory }}/bin/H5parm_importer.py
h5parm2.argument.flags = [-v,outputkey,globaldb2.output.mapfile]
### Step: 16b
### --- Update mapfile for conversion to circular
listsoltable2.control.kind = plugin
listsoltable2.control.type = changeMapfile
listsoltable2.control.mapfile_in = h5parm2.output.mapfile
listsoltable2.control.add_name = :solcd
listsoltable2.control.newname = listsoltable2.mapfile
### Step: 19b
### --- Running losoto for performing Clock/TEC separation
losotoclock.control.type = executable_args
losotoclock.control.executable = {{ losoto_directory }}/bin/losoto
losotoclock.control.parsetasfile = True
losotoclock.control.args_format = losoto
losotoclock.argument.flags = [-v,h5parm2.output.mapfile]
losotoclock.argument.LoSoTo.Steps = [duplicatePbka, plotAi1, plotAi2, plotAi3, duplicatePbkp, plotPi1, plotPi2, plotPi3, plotPd, ct, plotCLOCK, plotTEC, plotTEC3, residuals, plotPr1, plotPr2, plotPr3, resetA]
losotoclock.argument.LoSoTo.Solset = [sol000]
losotoclock.argument.LoSoTo.Soltab = []
losotoclock.argument.LoSoTo.SolType = []
losotoclock.argument.LoSoTo.ant = []
losotoclock.argument.LoSoTo.pol = []
losotoclock.argument.LoSoTo.dir = []
losotoclock.argument.LoSoTo.Ncpu = {{ max_per_node }}
losotoclock.argument.LoSoTo.Steps.duplicatePbka.Operation = DUPLICATE
losotoclock.argument.LoSoTo.Steps.duplicatePbka.InTable = sol000/amplitude000
losotoclock.argument.LoSoTo.Steps.duplicatePbka.OutTable = sol000/amplitudeOrig000
losotoclock.argument.LoSoTo.Steps.plotAi1.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotAi1.Soltab = [sol000/amplitude000]
losotoclock.argument.LoSoTo.Steps.plotAi1.freq.minmax = [0,300e6,100]
losotoclock.argument.LoSoTo.Steps.plotAi1.Axes = time
losotoclock.argument.LoSoTo.Steps.plotAi1.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotAi1.ColorAxis = pol
losotoclock.argument.LoSoTo.Steps.plotAi1.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotAi1.Prefix = plots-clock/amp_
losotoclock.argument.LoSoTo.Steps.plotAi1.Columns = 4
losotoclock.argument.LoSoTo.Steps.plotAi1.FigSize = [20,20]
losotoclock.argument.LoSoTo.Steps.plotAi2.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotAi2.Soltab = [sol000/amplitude000]
losotoclock.argument.LoSoTo.Steps.plotAi2.time.minmax = [0,1e20,500]
losotoclock.argument.LoSoTo.Steps.plotAi2.Axes = freq
losotoclock.argument.LoSoTo.Steps.plotAi2.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotAi2.ColorAxis = pol
losotoclock.argument.LoSoTo.Steps.plotAi2.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotAi2.Prefix = plots-clock/amp_
losotoclock.argument.LoSoTo.Steps.plotAi3.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotAi3.Soltab = [sol000/amplitude000]
losotoclock.argument.LoSoTo.Steps.plotAi3.Axes = [time,freq]
losotoclock.argument.LoSoTo.Steps.plotAi3.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotAi3.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotAi3.Prefix = plots-clock/amp_
losotoclock.argument.LoSoTo.Steps.duplicatePbkp.Operation = DUPLICATE
losotoclock.argument.LoSoTo.Steps.duplicatePbkp.InTable = sol000/phase000
losotoclock.argument.LoSoTo.Steps.duplicatePbkp.OutTable = sol000/phaseOrig000
losotoclock.argument.LoSoTo.Steps.plotPi1.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPi1.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPi1.freq.minmax = [0,300e6,100]
losotoclock.argument.LoSoTo.Steps.plotPi1.Axes = time
losotoclock.argument.LoSoTo.Steps.plotPi1.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPi1.ColorAxis = pol
losotoclock.argument.LoSoTo.Steps.plotPi1.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPi1.Prefix = plots-clock/ph_
losotoclock.argument.LoSoTo.Steps.plotPi1.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPi1.MinMax = [-3.14,3.14]
losotoclock.argument.LoSoTo.Steps.plotPi1.Columns = 4
losotoclock.argument.LoSoTo.Steps.plotPi1.FigSize = [20,20]
losotoclock.argument.LoSoTo.Steps.plotPi2.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPi2.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPi2.time.minmax = [0,1e20,500]
losotoclock.argument.LoSoTo.Steps.plotPi2.Axes = freq
losotoclock.argument.LoSoTo.Steps.plotPi2.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPi2.ColorAxis = pol
losotoclock.argument.LoSoTo.Steps.plotPi2.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPi2.Prefix = plots-clock/ph_
losotoclock.argument.LoSoTo.Steps.plotPi2.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPi2.MinMax = [-3.14,3.14]
losotoclock.argument.LoSoTo.Steps.plotPi3.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPi3.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPi3.Axes = [time,freq]
losotoclock.argument.LoSoTo.Steps.plotPi3.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPi3.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPi3.Prefix = plots-clock/ph_
losotoclock.argument.LoSoTo.Steps.plotPi3.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPi3.MinMax = [-3.14,3.14]
losotoclock.argument.LoSoTo.Steps.plotPd.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPd.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPd.Axes = [time,freq]
losotoclock.argument.LoSoTo.Steps.plotPd.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPd.DiffAxis = pol
losotoclock.argument.LoSoTo.Steps.plotPd.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPd.Prefix = plots-clock/ph-dif_
losotoclock.argument.LoSoTo.Steps.plotPd.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPd.MinMax = [-1,+1]
losotoclock.argument.LoSoTo.Steps.ct.Operation = CLOCKTEC
losotoclock.argument.LoSoTo.Steps.ct.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.ct.CombinePol = True
losotoclock.argument.LoSoTo.Steps.ct.FlagBadChannels = False
losotoclock.argument.LoSoTo.Steps.ct.Fit3rdOrder = True # only for very low-freq dataset
losotoclock.argument.LoSoTo.Steps.ct.Circular = False
losotoclock.argument.LoSoTo.Steps.plotCLOCK.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotCLOCK.Soltab = [sol000/clock000]
losotoclock.argument.LoSoTo.Steps.plotCLOCK.Axes = [time]
losotoclock.argument.LoSoTo.Steps.plotCLOCK.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotCLOCK.Prefix = plots-clock/clock
losotoclock.argument.LoSoTo.Steps.plotCLOCK.PlotFlag = False
losotoclock.argument.LoSoTo.Steps.plotCLOCK.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotTEC.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotTEC.Soltab = [sol000/tec000]
losotoclock.argument.LoSoTo.Steps.plotTEC.Axes = [time]
losotoclock.argument.LoSoTo.Steps.plotTEC.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotTEC.Prefix = plots-clock/tec
losotoclock.argument.LoSoTo.Steps.plotTEC.MinMax = [-0.5,0.5]
losotoclock.argument.LoSoTo.Steps.plotTEC.PlotFlag = False
losotoclock.argument.LoSoTo.Steps.plotTEC.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotTEC3.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotTEC3.Soltab = [sol000/tec3rd000]
losotoclock.argument.LoSoTo.Steps.plotTEC3.Axes = [time]
losotoclock.argument.LoSoTo.Steps.plotTEC3.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotTEC3.Prefix = plots-clock/tec3rd
losotoclock.argument.LoSoTo.Steps.plotTEC3.MinMax = [-300,300]
losotoclock.argument.LoSoTo.Steps.plotTEC3.PlotFlag = False
losotoclock.argument.LoSoTo.Steps.plotTEC3.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.residuals.Operation = RESIDUALS
losotoclock.argument.LoSoTo.Steps.residuals.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.residuals.Sub = [sol000/tec000,sol000/clock000,sol000/tec3rd000] # only for very low-freq dataset
losotoclock.argument.LoSoTo.Steps.plotPr1.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPr1.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPr1.freq.minmax = [0,300e6,100]
losotoclock.argument.LoSoTo.Steps.plotPr1.Axes = time
losotoclock.argument.LoSoTo.Steps.plotPr1.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPr1.ColorAxis = pol
losotoclock.argument.LoSoTo.Steps.plotPr1.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPr1.Prefix = plots-clock/phRes_
losotoclock.argument.LoSoTo.Steps.plotPr1.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPr1.MinMax = [-3.14,3.14]
losotoclock.argument.LoSoTo.Steps.plotPr1.Columns = 4
losotoclock.argument.LoSoTo.Steps.plotPr1.FigSize = [20,20]
losotoclock.argument.LoSoTo.Steps.plotPr2.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPr2.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPr2.time.minmax = [0,1e20,500]
losotoclock.argument.LoSoTo.Steps.plotPr2.Axes = freq
losotoclock.argument.LoSoTo.Steps.plotPr2.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPr2.ColorAxis = pol
losotoclock.argument.LoSoTo.Steps.plotPr2.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPr2.Prefix = plots-clock/phRes_
losotoclock.argument.LoSoTo.Steps.plotPr2.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPr2.MinMax = [-3.14,3.14]
losotoclock.argument.LoSoTo.Steps.plotPr3.Operation = PLOT
losotoclock.argument.LoSoTo.Steps.plotPr3.Soltab = [sol000/phase000]
losotoclock.argument.LoSoTo.Steps.plotPr3.Axes = [time,freq]
losotoclock.argument.LoSoTo.Steps.plotPr3.TableAxis = ant
losotoclock.argument.LoSoTo.Steps.plotPr3.PlotFlag = True
losotoclock.argument.LoSoTo.Steps.plotPr3.Prefix = plots-clock/phRes_
losotoclock.argument.LoSoTo.Steps.plotPr3.Reference = {{ reference_station }}
losotoclock.argument.LoSoTo.Steps.plotPr3.MinMax = [-3.14,3.14]
losotoclock.argument.LoSoTo.Steps.resetA.Operation = RESET
losotoclock.argument.LoSoTo.Steps.resetA.Soltab = [sol000/amplitude000]
### Step: 19c
### --- Export bandpass, phases and clock from h5parm to globaldb-clock
h5parmexpclock.control.type = executable_args
h5parmexpclock.control.executable = {{ scripts }}/H5parm_exporter.py
h5parmexpclock.argument.flags = [-v,-c,-t,"amplitude000;{{ tables2export }}",h5parm2.output.mapfile,globaldbampclock.output.mapfile]
### Step: 20a
### --- Merge final globaldb
h5parmmerge.control.type = executable_args
h5parmmerge.control.executable = {{ losoto_directory }}/bin/H5parm_merge.py
h5parmmerge.argument.flags = [listsoltableCD.output.mapfile,listsoltable2.output.mapfile]
### Step: 20b
### --- Duplicate tables
losotomerge.control.type = executable_args
losotomerge.control.executable = {{ losoto_directory }}/bin/losoto
losotomerge.control.parsetasfile = True
losotomerge.control.args_format = losoto
losotomerge.argument.flags = [-v,h5parm2.output.mapfile]
losotomerge.argument.LoSoTo.Steps = [duplicate]
losotomerge.argument.LoSoTo.Ncpu = {{ max_per_node }}
losotomerge.argument.LoSoTo.Steps.duplicate.Operation = DUPLICATE
losotomerge.argument.LoSoTo.Steps.duplicate.InTable = solcd/amplitudeSmooth000
losotomerge.argument.LoSoTo.Steps.duplicate.OutTable = sol000/amplitudeSmooth000
### Step: 20c
### --- Export final globaldb
h5parmexp.control.type = executable_args
h5parmexp.control.executable = {{ scripts }}/H5parm_exporter.py
h5parmexp.argument.flags = [-v,-c,-t,"amplitudeSmooth000;{{ tables2export }}",h5parm2.output.mapfile,globaldbampclock.output.mapfile]
################################################################################################################################################################################################################################################################
## ##
## End of calibrator pipeline ##
## ##
################################################################################################################################################################################################################################################################