forked from tonywong94/idl_mommaps
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpltmom.pro
152 lines (130 loc) · 4.43 KB
/
pltmom.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
PRO PLTMOM,prefix,scale=scale,label=label
;+
; NAME:
; PLTMOM
;
; PURPOSE:
; summary plot for mom0 and mom1 maps
;
; INPUTS:
; PREFIX -- prefix for maps
; e.g.'yourpath/n4254co.gm'
; label -- .xtitle
; .ytitle
; .tl
; .tr
; .bl
; .bt
;
; OUTPUTS:
; prefix.mom01.eps
;
; HISTORY:
;
; 20130214 RX introduced
; 20130910 RX changed to absolute coordinate
; 20150910 RX merged from makemom_pl.pro
; clean up dependency
; correct a bug related to BPA
;-
; CHECK IMAGE FILES
if ~file_test(prefix+'.mom0.fits') or $
~file_test(prefix+'.emom0max.fits') or $
~file_test(prefix+'.mom1.fits') then begin
print,'no mom0/emom0/mom1 image found'
return
endif
set_plot, 'ps'
device, filename=prefix+'.mom01.eps', $
bits_per_pixel=8,/encapsulated,$
xsize=8,ysize=4.8,/inches,/col,xoffset=0,yoffset=0
!p.thick = 1.5
!x.thick = 1.5
!y.thick = 1.5
!z.thick = 1.5
!p.charsize=1.0
!p.charthick=1.5
xyouts,'!6'
eim=prefix+'.emom0max.fits'
eim=READFITS(eim,eimhd,/SILENT)
for i=0,1 do begin
im=prefix+'.mom'+strtrim(i,2)+'.fits'
im=READFITS(im,imhd)
if n_elements(scale) ne 0 and i eq 0 then im=im*scale
pos=[0.08,0.1,0.52,0.85]+i*[0.46,0.0,0.46,0.0]
; COLOR SCALING
loadct,13,/SILENT
if i eq 0 then begin
minvalue=min(im,/nan)
maxvalue=max(im,/nan)
if minvalue eq maxvalue then begin
minvalue=-1 & maxvalue=1
endif
CGIMAGE,im,pos=pos,stretch=1,/noe,/KEEP_ASPECT_RATIO,minvalue=minvalue,maxvalue=maxvalue
endif
if i eq 1 then begin
CGIMAGE,im,pos=pos,stretch=1,/noe,/KEEP_ASPECT_RATIO
endif
RADIOHEAD,imhd,s=s
psize=abs(s.cdelt[0])*3600
sz=size(im,/d)
loadct,0,/SILENT
xtitle=''
ytitle=''
xmid=!null
ymid=!null
if keyword_set(label) then begin
if tag_exist(label,'xtitle') then xtitle=label.xtitle
if tag_exist(label,'ytitle') and i eq 0 then ytitle=label.ytitle
if tag_exist(label,'xmid') then xmid=label.xmid
if tag_exist(label,'ymid') then ymid=label.ymid
endif
if i eq 1 then ytickformat='(A1)' else ytickformat=''
imcontour,im,imhd,$
/noe,/nodata,pos=pos,$
title=dataid,xtitle=xtitle,ytitle=ytitle,/overlay,$
ytickformat=ytickformat,$
subtitle=' ',xmid=xmid,ymid=ymid,$
color='black',AXISCOLOR='black'
imcontour,im,imhd,$
/noe,/nodata,pos=pos,$
title=dataid,/overlay,$
ytickformat='(A1)',xtickformat='(A1)',$
xtitle=' ',ytitle=' ',$
subtitle=' ',xmid=xmid,ymid=ymid,$
color='black',AXISCOLOR='red'
if (where(eim ne eim))[0] ne -1 then begin
bb=find_boundary(where(eim eq eim),xsize=sz[0],ysize=sz[1])
oplot,bb[0,*],bb[1,*],color=cgcolor('white'),linestyle=2
endif
pos=[pos[0],pos[3],pos[2],pos[3]]+[0.0,0.06,0.0,0.10]
loadct,13,/SILENT
if i eq 0 then title='Intensity ['+strtrim(sxpar(imhd,'BUNIT'),2)+']'
if i eq 1 then title='Velocity Field ['+strtrim(sxpar(imhd,'BUNIT'),2)+']'
crange=[min(im,/nan),max(im,/nan)]
tickint=fix(crange[1]-crange[0])/5
if crange[0] eq crange[1] or (where(im eq im))[0] eq -1 then crange=[-1.,1.]
cgCOLORBAR, range=crange, POSITION=pos,title=title,tlocation='TOP',tickinterval=tickint
loadct,0,/SILENT
getrot,imhd,rotang,cdelt
imsz=size(im,/d)
rotang_s=rotang+45.0
ds=30./2.0/512*min(imsz)*sqrt(2)
xc=imsz[0]*0.92
yc=imsz[1]*0.08
one_arrow,xc+ds*sin(rotang_s/180*!dpi),yc-ds*cos(rotang_s/180*!dpi),+90+rotang,'N',color='yellow',/data,charsize=1.0
one_arrow,xc+ds*sin(rotang_s/180*!dpi),yc-ds*cos(rotang_s/180*!dpi),+180+rotang,'E',color='yellow',/data,charsize=1.0
tvellipse,s.bmaj/2.0/psize,s.bmin/2.0/psize,$
sz[0]/10.0,sz[1]/10.0,$
s.bpa-90.0+rotang,$
/data,noclip=0,color=cgcolor('cyan'),/fill
if keyword_set(label) then begin
if tag_exist(label,'tl') then al_legend,label.tl,/top,/left,textcolor='yellow',box=0
if tag_exist(label,'tr') then al_legend,label.tr,/top,/right,textcolor='yellow',box=0
if tag_exist(label,'bl') then al_legend,label.bl,/bottom,/left,textcolor='yellow',box=0
if tag_exist(label,'br') then al_legend,label.br,/bottom,/right,textcolor='yellow',box=0
endif
endfor
device, /close
set_plot,'X'
END