0001 function [dfake dobs]= Fake_Raster(input_mangle_matrix,mangle_name,dfake)
0002
0003
0004
0005
0006
0007
0008
0009
0010 [home,installeddir] = where_am_i();
0011 addpath([home,'/',installeddir,'/Angelas_Raster_Code/']);
0012 maindir= [home,'/',installeddir,'/'];
0013
0014
0015
0016 datadir='Raster_Tests_Jul14'
0017 datadir_fits = ['n_raster_elliptical_newcal_',mangle_name,'_jul14']
0018
0019
0020
0021 input_date='17-Jul-2013';
0022 pipelined_file='17-Jul-2013:13:53:34_taua_I_pipelined';
0023 if(~exist('dfake'));
0024 load(['./',datadir,'/',pipelined_file,'.mat'])
0025 cal_source='TauA';
0026 source_name='TauA';
0027
0028
0029
0030
0031
0032 disp('Getting Equatorial co-ordinates');
0033 d = calcRADECJ2000(d)
0034
0035
0036
0037
0038
0039
0040
0041
0042
0043
0044
0045
0046
0047
0048
0049
0050
0051
0052
0053
0054
0055
0056 RA = rad2deg(d.antenna0.servo.equa(:,1));
0057 DEC = rad2deg(d.antenna0.servo.equa(:,2));
0058
0059 [RA_tau DEC_tau] = sourcePos(source_name);
0060
0061 RA_off = RA-RA_tau;
0062 DEC_off = DEC-DEC_tau;
0063 RA_off = RA_off.*(cosd(DEC));
0064
0065 distance = sqrt(RA_off.^2 + DEC_off.^2);
0066
0067
0068
0069
0070
0071 mjd=tstr2mjd('17-Jul-2014:13:53');
0072 [sourceNum sourceFlux fluxErr polang polfrac] = ...
0073 sourceCorrespondance({cal_source}, mjd);
0074
0075
0076
0077 [antenna_no antenna_name] = identifyTelescope(d);
0078 telescope_constants;
0079 Tsrc = sourceFlux.*(dishArea*apEff)./(2*k_b*1e26);
0080 model = [Tsrc polfrac polang]
0081
0082
0083
0084 fwhm = 0.74
0085 sigma = fwhm/(2*sqrt(2*log(2)))
0086 beam = exp((-distance.^2)./(2*sigma^2));
0087
0088
0089
0090
0091
0092 LAT_D = antenna_latitude(antenna_no)
0093 LON_D = antenna_longitude(antenna_no)
0094
0095 JD = mjd2jd(d.antenna0.receiver.utc);
0096 LST=lst(JD,deg2rad(LON_D),'m');
0097
0098
0099
0100 d = calcRADECcurrent(d);
0101 RA_current = d.antenna0.servo.equa(:,1);
0102 DEC_current = d.antenna0.servo.equa(:,2);
0103
0104 [PA]=parallactic_angle((RA_current),(DEC_current),LST,deg2rad(LAT_D));
0105 PA_D = rad2deg(PA);
0106
0107
0108 d = calcRADECJ2000(d);
0109
0110
0111
0112
0113
0114
0115
0116
0117
0118 dfake = d;
0119
0120 dfake.antenna0.receiver.data(:,1) = Tsrc*beam;
0121 dfake.antenna0.receiver.data(:,8) = Tsrc*beam;
0122
0123 dfake.antenna0.receiver.data(:,2) = Tsrc*beam*polfrac.*cosd(2*(polang+PA_D));
0124 dfake.antenna0.receiver.data(:,4) = Tsrc*beam*polfrac.*cosd(2*(polang+PA_D));
0125 dfake.antenna0.receiver.data(:,6) = Tsrc*beam*polfrac.*cosd(2*(polang+PA_D));
0126
0127 dfake.antenna0.receiver.data(:,3) = Tsrc*beam*polfrac.*sind(2*(polang+PA_D));
0128 dfake.antenna0.receiver.data(:,5) = Tsrc*beam*polfrac.*sind(2*(polang+PA_D));
0129 dfake.antenna0.receiver.data(:,7) = Tsrc*beam*polfrac.*sind(2*(polang+PA_D));
0130
0131
0132
0133
0134
0135
0136
0137 [dist az el] = calcSourceDist(dfake, 'sun');
0138 dfake.antenna0.servo.solarDist = dist;
0139 az = wrap360(az);
0140 raz=round(60*az);
0141 raz(raz >= 21600) = 0;
0142 dfake.flags.dayNight = ones(size(az),'uint8');
0143
0144
0145 datadir_fits = ['n_raster_elliptical_newcal_',mangle_name,'_jul14']
0146 end
0147
0148
0149
0150
0151
0152
0153
0154
0155
0156
0157
0158
0159
0160
0161
0162
0163
0164
0165
0166
0167
0168
0169
0170
0171
0172
0173
0174
0175
0176
0177
0178
0179
0180
0181
0182
0183
0184
0185
0186 mangle=input_mangle_matrix;
0187
0188
0189 trueS = [dfake.antenna0.receiver.data(:,[1,2,3])];
0190
0191 obsS = trueS*mangle;
0192
0193
0194 dobs=dfake;
0195 dobs.antenna0.receiver.data(:,1) = obsS(:,1);
0196 dobs.antenna0.receiver.data(:,2) = obsS(:,3);
0197 dobs.antenna0.receiver.data(:,3) = obsS(:,5);
0198 dobs.antenna0.receiver.data(:,4) = obsS(:,4);
0199 dobs.antenna0.receiver.data(:,5) = obsS(:,6);
0200 dobs.antenna0.receiver.data(:,6) = (obsS(:,3)+obsS(:,4))/2;
0201 dobs.antenna0.receiver.data(:,7) = (obsS(:,5)+obsS(:,6))/2;
0202 dobs.antenna0.receiver.data(:,8) = obsS(:,2);
0203
0204
0205
0206
0207
0208
0209
0210
0211
0212
0213 [dist az el] = calcSourceDist(dobs, 'sun');
0214 dobs.antenna0.servo.solarDist = dist;
0215 az = wrap360(az);
0216 raz=round(60*az);
0217 raz(raz >= 21600) = 0;
0218 dobs.flags.dayNight = ones(size(az),'uint8');
0219
0220 dred = reduceData(dobs,'redScript_newcal_raster_2014_fits.red',0,datadir_fits)
0221
0222 reduced_data_file = strcat([pipelined_file,'_',mangle_name,'.mat'])
0223 save([maindir,datadir,'/',reduced_data_file],'dobs','-v7.3')
0224
0225
0226
0227
0228 descart_file=mangle(:,[1 2 3 5 4 6])';
0229
0230
0231
0232 save([maindir,datadir,'/leakage_',mangle_name,'.txt'],'descart_file','-ascii','-v7.3')
0233 fitspath=[maindir,'reduc/',datadir_fits,'/',input_date,'*/fits/*.fits'] ;
0234 newfitsfile=[maindir,datadir,'/',input_date,'_',mangle_name,'_nodetrend.fits']
0235 system(['cp ',fitspath,' ',newfitsfile ])
0236
0237
0238
0239 cd ([datadir])
0240 system(['ls ',input_date,'_',mangle_name,'_nodetrend.fits > files.txt'])
0241
0242 current_ld_lib_path = getenv('LD_LIBRARY_PATH');
0243 setenv('LD_LIBRARY_PATH',['/usr/local/shared/cfitsio/lib/:',current_ld_lib_path]);
0244
0245 system(['descart_cbass ./default_params.ini do_polarization=T naive_mode=T nside=1024 subtractMeans=F leakage_matrix=leakage_fake0.txt output_filename=',mangle_name,'_map_noC.fits'])
0246
0247 system(['descart_cbass ./default_params.ini do_polarization=T naive_mode=T nside=1024 subtractMeans=F leakage_matrix=leakage_',mangle_name,'.txt output_filename=',mangle_name,'_map.fits'])
0248
0249 system(['python plot_maps.py ',mangle_name,'_map.fits ',mangle_name,'_map.png'])
0250 system(['python plot_maps.py ',mangle_name,'_map_noC.fits ',mangle_name,'_map_noC.png'])
0251 cd ([maindir])