-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDR3calcHINSA.pro
274 lines (215 loc) · 8.4 KB
/
DR3calcHINSA.pro
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
PRO timemark
common time,runtime,resultfolder
print,'Start!',systime()
runtime=string(systime())
; resultfolder=strcompress('/mnt/science1/bliu/HINSA/data/result/'+string(runtime)+'/')
resultfolder=strcompress('/mnt/science1/bliu/HINSA/code/20190813/')
FILE_MKDIR,resultfolder
return
END
PRO readHIfits
common HIfits,a,head,bw,freq,nx,ny,nz,crvalx,cdeltax,crpixx,crvaly,cdeltay,crpixy,crvalz,cdeltaz,crpixz,ctypey,x,y,z,zhel,vchannel
fitsname='/mnt/science1/bliu/HINSA/data/HI.fits'
a=mrdfits(fitsname) ;HI
head=headfits(fitsname);read the header of the fits file to a vector
bw= fxpar(head,'BW'); band width (MHz)
freq= fxpar(head,'LINEFREQ'); central frequency (GHz)
nx= fxpar(head,'NAXIS1'); number of elements in the first dimension
ny= fxpar(head,'NAXIS2');
nz= fxpar(head,'NAXIS3');
crvalx= fxpar(head,'CRVAL1'); reference value of the first dimension
cdeltax = fxpar(head,'CDELT1'); increasement of the first dimension
; in units of degree, when calculate physical
; scale, must changed to arcdegree
crpixx= fxpar(head,'CRPIX1'); reference position of the first dimension
crvaly= fxpar(head,'CRVAL2');
cdeltay = fxpar(head,'CDELT2');
crpixy= fxpar(head,'CRPIX2');
crvalz= fxpar(head,'CRVAL3');
cdeltaz = fxpar(head,'CDELT3');
crpixz= fxpar(head,'CRPIX3');
ctypey= fxpar(head,'CTYPE2');
x=(dindgen(nx)+0.5-crpixx)*cdeltax+crvalx;
y=(dindgen(ny)+0.5-crpixy)*cdeltay+crvaly;
z=(dindgen(nz)+0.5-crpixz)*cdeltaz+crvalz;
z=z/1.0e3
zhel=z
vchannel=abs(cdeltaz)/1.0e3; km/s
print,'HI fits read! ',systime()
END
PRO readCOfits
common COfits,a12co,head12co,bw12co,freq12co,nx12co,ny12co,nz12co,crvalx12co,cdeltax12co,crpixx12co,$
crvaly12co,cdeltay12co,crpixy12co,crvalz12co,cdeltaz12co,crpixz12co,x12co,y12co,z12co,vchannel12co
fitsname12co='/mnt/science1/bliu/HINSA/data/LMC_MAGMA_DR3.co.base.fits'
a12co=mrdfits(fitsname12co)
head12co=headfits(fitsname12co);read the header of the fits file to a vector
bw12co= fxpar(head12co,'BW'); band width (MHz)
freq12co= fxpar(head12co,'LINEFREQ'); central frequency (GHz)
nx12co= fxpar(head12co,'NAXIS1'); number of elements in the first dimension
ny12co= fxpar(head12co,'NAXIS2');
nz12co= fxpar(head12co,'NAXIS3');
crvalx12co= fxpar(head12co,'CRVAL1'); reference value of the first dimension
cdeltax12co = fxpar(head12co,'CDELT1'); increasement of the first dimension
; in units of degree, when calculate physical
; scale, must changed to arcdegree
crpixx12co= fxpar(head12co,'CRPIX1'); reference position of the first dimension
crvaly12co= fxpar(head12co,'CRVAL2');
cdeltay12co = fxpar(head12co,'CDELT2');
crpixy12co= fxpar(head12co,'CRPIX2');
crvalz12co= fxpar(head12co,'CRVAL3');
cdeltaz12co = fxpar(head12co,'CDELT3');
crpixz12co= fxpar(head12co,'CRPIX3');
x12co=(dindgen(nx12co)+0.5-crpixx12co)*cdeltax12co+crvalx12co;
y12co=(dindgen(ny12co)+0.5-crpixy12co)*cdeltay12co+crvaly12co;
z12co=(dindgen(nz12co)+0.5-crpixz12co)*cdeltaz12co+crvalz12co;
z12co=z12co/1.0e3
vchannel12co=abs(cdeltaz12co)/1.0e3; km/s
print,'CO fits read! ',systime()
END
PRO readCOmasksumfits
common COmasksumfits,a12comasksum
fitsname12comasksum='/mnt/science1/bliu/HINSA/data/gm/LMC_MAGMA_DR3.co.gm.mask_sum.fits'
a12comasksum=mrdfits(fitsname12comasksum)
print,'COmasksum fits read! ',systime()
END
PRO readCOmaskfits
common COmaskfits,a12comask
fitsname12comask='/mnt/science1/bliu/HINSA/data/LMC_MAGMA_DR3.co.sgm.mask.fits'
a12comask=mrdfits(fitsname12comask)
print,'COmask fits read! ',systime()
END
PRO readCOsnrpkfits
common COsnrpkfits,a12cosnrpk
fitsname12cosnrpk='/mnt/science1/bliu/HINSA/data/LMC_MAGMA_DR3.co.snrpk.fits'
a12cosnrpk=mrdfits(fitsname12cosnrpk)
print,'COsnrpk fits read! ',systime()
END
PRO readxyHItoCOfits
common xyHItoCOfits,xyHItoCO
fitsnamexyHItoCO='/mnt/science1/bliu/HINSA/data/xyHItoCO.fit'
xyHItoCO=mrdfits(fitsnamexyHItoCO)
print,'xyHItoCO fits read!',systime()
END
FUNCTION chi2,x
COMMON share,specmodel,zchi,THchi,vH,sigmaHchi,vchannelchi
tau0 = x[0] ;tau0 is the optical depth of HINSA at vH
tau=tau0*exp(-(zchi-vH)^2/(2.0*sigmaHchi^2))
specorigin=specmodel*exp(tau)-THchi*(exp(tau)-1.0)
dspec=deriv(zchi,specorigin) ; derivative
ddspec=deriv(zchi,dspec) ; second order derivative
result=total(ddspec^2*vchannelchi)
return,result
END
PRO calcHINSA,HIarray,COarray,maskarray,z,z12CO,vchannel,HINSAarray,TH,tau0,sigmaH,warning
COMMON share
zchi=z
vchannelchi=vchannel
spec=HIarray
specmodel=spec
gsfit=gaussfit(z12CO,COarray,result,NTERMS=3)
model12CO=(result(0)*exp(-((z12CO-result(1))/result(2))^2/2.0))
ck=1.3806488e-16 ;cm^2 g s^-2 K^-1, Boltzmann constant
TB0=result(0) ;K, 12CO observed brightness temperature at line center
T0=5.53 ;K, 12CO J=1-0 equivalent temperature
Tbg=2.73 ;K, CMB
Tex=T0/alog(1+1/(TB0/T0+1/(exp(T0/Tbg)-1))) ;K, 12CO excit T, formula(A1), Krco 2008 ;13.7.23
Texcorrected=Tex*1.0 ;at tau=5, Tex_corr factor = 0.99 ~1.0
tk=Texcorrected ;K, kinetic temperature
TH=tk
vH=result(1) ;CO & HINSA central velocity
AvoCons=6.02214129d23 ;Avogadro constant
mH=1.00794/AvoCons ;g
mCO=28.010/AvoCons ;g
sigmaH=sqrt((result(2))^2+2*ck*TH*(1/mH-1/mCO)/1.0d10) ;line width, using 201406 version draft's formula
sigmaHchi=sigmaH
THchi=TH
if maskarray((where(model12CO eq max(model12CO)))(0)) eq 1 then begin
if result(2) lt 3.8 then begin
ftol = 1.0e-5
point=AMOEBA(ftol,SCALE=[1.0],P0=[0.15],FUNCTION_VALUE=fval,FUNCTION_NAME='chi2')
tau0=point(0)
tau=tau0*exp(-(z-vH)^2/(2.0*sigmaH^2))
specorigin=spec*exp(tau)-TH*(exp(tau)-1.0)
; =>HINSA=Sori-Sobs=(Sobs-Tex)*(exp(tau)-1), thus HINSA profile is not central symmetric.
HINSAarray=specorigin-spec
warning=0
endif else begin
warning=1
HINSAarray=HINSAarray*0
tau0=0
endelse
endif else begin
warning=2
HINSAarray=HINSAarray*0
tau0=0
endelse
END
PRO DR3calcHINSA
timemark
readHIfits
readCOfits
readCOmasksumfits
readCOmaskfits
readCOsnrpkfits
readxyHItoCOfits
common time
common HIfits
common COfits
common COmasksumfits
common COmaskfits
common COsnrpkfits
common xyHItoCOfits
xyad,head12CO,0,0,a0,d0
xyad,head12CO,nx12CO-1,ny12CO-1,a1,d1
adxy,head,a0,d0,x0,y0
adxy,head,a1,d1,x1,y1
print,x0,y0,x1,y1
HINSAcube=make_array(nx,ny,nz)
THcube=make_array(nx,ny)
tau0cube=make_array(nx,ny)
sigmaHcube=make_array(nx,ny)
for xHI=fix(x0),fix(x1) do begin
for yHI=fix(y0),fix(y1) do begin
x12CO=xyHItoCO(xHI,yHI,2)
y12CO=xyHItoCO(xHI,yHI,3)
if (x12CO gt 0) AND (y12CO gt 0) AND (x12CO lt nx12CO) AND (y12CO lt ny12CO) then begin
if a12comasksum(x12CO,y12CO) ge 3 && a12cosnrpk(x12CO,y12CO) ge 6 then begin
HIarray=reform(a(xHI,yHI,*))
COarray=reform(a12CO(x12CO,y12CO,*))
maskarray=reform(a12COmask(x12CO,y12CO,*))
save,HIarray,filename=resultfolder+'HIarray.sav'
save,COarray,filename=resultfolder+'COarray.sav'
save,z,filename=resultfolder+'z.sav'
save,z12CO,filename=resultfolder+'z12CO.sav'
save,vchannel,filename=resultfolder+'vchannel.sav'
calcHINSA,HIarray,COarray,maskarray,z,z12CO,vchannel,HINSAarray,TH,tau0,sigmaH,warning
if warning eq 1 then print,xHI,yHI,' Fitted CO width too wide: > 3.8 km/s'
if warning eq 2 then print,xHI,yHI,' Fitted CO peak out of mask window.'
if tau0 lt -1 then print,xHI,yHI,x12CO,y12CO,tau0,sigmaH,a12comasksum(x12CO,y12CO)
HINSAcube(xHI,yHI,*)=HINSAarray
THcube(xHI,yHI)=TH
tau0cube(xHI,yHI)=tau0
sigmaHcube(xHI,yHI)=sigmaH
endif else begin
;print,xHI,yHI,' Low quality data. Pass.'
endelse
endif else begin
;print,xHI,yHI,' Out of boundry'
endelse
endfor
endfor
print,'lets write'
outhead0=head
outhead1=head
sxaddpar,outhead1,'NAXIS',2
sxdelpar,outhead1,['NAXIS3','CRPIX3','CDELT3','CRVAL3','CTYPE3']
outfilename=strcompress(resultfolder+'DR3HINSAcube.fits')
mwrfits,HINSAcube,outfilename,outhead0
outfilename=strcompress(resultfolder+'DR3THcube.fits')
mwrfits,THcube,outfilename,outhead1
outfilename=strcompress(resultfolder+'DR3tau0cube.fits')
mwrfits,tau0cube,outfilename,outhead1
outfilename=strcompress(resultfolder+'DR3sigmaHcube.fits')
mwrfits,sigmaHcube,outfilename,outhead1
print,'finished ',systime()
END