CFTerms.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 #ifndef SYNTHESIS_CFTERMS_H
00030 #define SYNTHESIS_CFTERMS_H
00031
00032
00033 #include <casa/Arrays/Vector.h>
00034 #include <images/Images/ImageInterface.h>
00035 #include <images/Images/PagedImage.h>
00036 #include <images/Images/TempImage.h>
00037 #include <msvis/MSVis/VisBuffer.h>
00038 #include <casa/Containers/Block.h>
00039
00040 namespace casa{
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051
00052
00053
00054
00055 class CFTerms
00056 {
00057 public:
00058 enum OpCodes {NOOP=0,NORMAL};
00059 CFTerms ():opCode_p(NORMAL) {};
00060 virtual ~CFTerms () {};
00061
00062 virtual void setOpCode(OpCodes code) {opCode_p = code;}
00063 virtual Bool isNoOp() {return opCode_p==NOOP;};
00064
00065 virtual String name() = 0;
00066
00067 virtual void applySky(ImageInterface<Float>& outputImages,
00068 const VisBuffer& vb,
00069 const Bool doSquint=True,
00070 const Int& cfKey=0,
00071 const Int& muellerTerms=0,
00072 const Double freqVal=-1) = 0;
00073 virtual void applySky(ImageInterface<Complex>& outputImages,
00074 const VisBuffer& vb,
00075 const Bool doSquint=True,
00076 const Int& cfKey=0,
00077 const Int& muellerTerms=0,
00078 const Double freqVal=-1) = 0;
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101 virtual Vector<Int> vbRow2CFKeyMap(const VisBuffer& vb, Int& nUnique) = 0;
00102 virtual Int makePBPolnCoords(const VisBuffer& vb,
00103 const Int& convSize,
00104 const Int& convSampling,
00105 const CoordinateSystem& skyCoord,
00106 const Int& skyNx, const Int& skyNy,
00107 CoordinateSystem& feedCoord) = 0;
00108
00109 virtual Int getConvSize() = 0;
00110 virtual Int getOversampling() = 0;
00111 virtual Float getConvWeightSizeFactor() = 0;
00112 virtual Float getSupportThreshold() = 0;
00113
00114 virtual void normalizeImage(Lattice<Complex>& skyImage,
00115 const Matrix<Float>& weights) = 0;
00116
00117 virtual int getVisParams(const VisBuffer& vb, const CoordinateSystem& skyCoord=CoordinateSystem()) = 0;
00118
00119
00120
00121
00122
00123
00124
00125
00126 virtual void setPolMap(const Vector<Int>& polMap) {polMap_p_base.resize(0);polMap_p_base=polMap;}
00127 virtual void getPolMap(Vector<Int>& polMap) {polMap.resize(0); polMap = polMap_p_base;};
00128
00129 virtual Bool rotationallySymmetric() = 0;
00130
00131 protected:
00132 LogIO& logIO() {return logIO_p;}
00133 LogIO logIO_p;
00134 Vector<Int> polMap_p_base;
00135 OpCodes opCode_p;
00136 };
00137
00138 };
00139
00140 #endif