Commit 8c683fa4d0c37275a76d37ba076865d84448bc19
1 parent
b78f1109
Exists in
master
First commit
Showing
3 changed files
with
266 additions
and
0 deletions
Show diff stats
@@ -0,0 +1,89 @@ | @@ -0,0 +1,89 @@ | ||
1 | +PRO phangs_make_co_images,source_name=source_name,save=save,show_images=show_images,nostop=nostop,help=help | ||
2 | + | ||
3 | +;+ | ||
4 | +; NAME: | ||
5 | +; phangs_make_co_images | ||
6 | +; PURPOSE: | ||
7 | +; makes JWST images usable by the Phangs ISRF project | ||
8 | +; CATEGORY: | ||
9 | +; Dustem Phangs | ||
10 | +; CALLING SEQUENCE: | ||
11 | +; phangs_make_co_images[,source_name=][,/save][,/show_images][,/nostop] | ||
12 | +; INPUTS: | ||
13 | +; None | ||
14 | +; OPTIONAL INPUT PARAMETERS: | ||
15 | +; source_name : source name (default = 'ngc0628') | ||
16 | +; OUTPUTS: | ||
17 | +; None | ||
18 | +; OPTIONAL OUTPUT PARAMETERS: | ||
19 | +; None | ||
20 | +; ACCEPTED KEY-WORDS: | ||
21 | +; help = If set, print this help | ||
22 | +; save = If set, save result | ||
23 | +; show_images= if set, show images | ||
24 | +; nostop = if set, does not stop | ||
25 | +; COMMON BLOCKS: | ||
26 | +; None | ||
27 | +; SIDE EFFECTS: | ||
28 | +; A file is written | ||
29 | +; RESTRICTIONS: | ||
30 | +; None | ||
31 | +; PROCEDURE: | ||
32 | +; input JWST images are asumed to be in units of MJy/sr | ||
33 | +; EXAMPLES | ||
34 | +; phangs_make_co_images,source_name='ngc0628',/save,/show,/nostop | ||
35 | +; MODIFICATION HISTORY: | ||
36 | +; Written by J.-Ph. Bernard (2023) | ||
37 | +; Evolution details on the DustEMWrap gitlab. | ||
38 | +; See http://dustemwrap.irap.omp.eu/ for FAQ and help. | ||
39 | +;- | ||
40 | + | ||
41 | +IF keyword_set(help) THEN BEGIN | ||
42 | + doc_library,'phangs_make_co_images' | ||
43 | + goto,the_end | ||
44 | +ENDIF | ||
45 | + | ||
46 | +dustem_define_la_common | ||
47 | + | ||
48 | +use_source_name='ngc0628' | ||
49 | +IF keyword_set(source_name) THEN use_source_name=source_name | ||
50 | + | ||
51 | +save_data_dir=!phangs_data_dir+'/ISRF/WORK/' | ||
52 | +file=save_data_dir+use_source_name+'_ref_header.sav' | ||
53 | +restore,file,/verb | ||
54 | +;% RESTORE: Restored variable: HREF. | ||
55 | + | ||
56 | +Nx=sxpar(href,'NAXIS1') | ||
57 | +Ny=sxpar(href,'NAXIS2') | ||
58 | + | ||
59 | +data_dir=!phangs_data_dir+'/phangs_drive/PHANGS_ALMA/' | ||
60 | + | ||
61 | +;WCO map: | ||
62 | +file=data_dir+use_source_name+'_12m+7m+tp_co21_broad_mom0.fits' | ||
63 | +d=readfits(file,h) | ||
64 | +;sxaddpar,h,'CTYPE1','RA---TAN' | ||
65 | +;sxaddpar,h,'CTYPE2','RA---TAN' | ||
66 | +sxaddpar,h,'EQUINOX',2000. | ||
67 | +ind=where(finite(d) NE 1,count) | ||
68 | +IF count NE 0 THEN d[ind]=la_undef() | ||
69 | +IF sxpar(h,'NAXIS1') NE Nx OR sxpar(h,'NAXIS2') NE Ny THEN WCO=project2(h,d,href,/silent) ELSE WCO=d | ||
70 | +fact=4.e20/1.e21 | ||
71 | +NHCO=la_mul(WCO,fact) ;NH from CO in 1e21 H/cm2 | ||
72 | +tit=source_name+' '+'NHCO [1e21 H/cm2]' | ||
73 | +IF keyword_set(show_images) THEN BEGIN | ||
74 | + win=0L | ||
75 | + window,win | ||
76 | + win=win+1 | ||
77 | + image_cont20,NHCO,href,/square,imrange=[-0.5,10],image_color_table='jpbloadct',/silent,tit=tit | ||
78 | + IF not keyword_set(nostop) THEN stop | ||
79 | +ENDIF | ||
80 | + | ||
81 | +IF keyword_set(save) THEN BEGIN | ||
82 | + save_file=save_data_dir+use_source_name+'_CO_images.sav' | ||
83 | + save,NHCO,href,file=save_file | ||
84 | + message,'Saved '+save_file,/continue | ||
85 | +ENDIF | ||
86 | + | ||
87 | +the_end: | ||
88 | + | ||
89 | +END | ||
0 | \ No newline at end of file | 90 | \ No newline at end of file |
@@ -0,0 +1,89 @@ | @@ -0,0 +1,89 @@ | ||
1 | +PRO phangs_make_hi_images,source_name=source_name,save=save,show_images=show_images,nostop=nostop,help=help | ||
2 | + | ||
3 | +;+ | ||
4 | +; NAME: | ||
5 | +; phangs_make_hi_images | ||
6 | +; PURPOSE: | ||
7 | +; makes HI images usable by the Phangs ISRF project | ||
8 | +; CATEGORY: | ||
9 | +; Dustem Phangs | ||
10 | +; CALLING SEQUENCE: | ||
11 | +; phangs_make_hi_images[,source_name=][,/save][,/show_images][,/nostop] | ||
12 | +; INPUTS: | ||
13 | +; None | ||
14 | +; OPTIONAL INPUT PARAMETERS: | ||
15 | +; source_name : source name (default = 'ngc0628') | ||
16 | +; OUTPUTS: | ||
17 | +; None | ||
18 | +; OPTIONAL OUTPUT PARAMETERS: | ||
19 | +; None | ||
20 | +; ACCEPTED KEY-WORDS: | ||
21 | +; help = If set, print this help | ||
22 | +; save = If set, save result | ||
23 | +; show_images= if set, show images | ||
24 | +; nostop = if set, does not stop | ||
25 | +; COMMON BLOCKS: | ||
26 | +; None | ||
27 | +; SIDE EFFECTS: | ||
28 | +; A file is written | ||
29 | +; RESTRICTIONS: | ||
30 | +; None | ||
31 | +; PROCEDURE: | ||
32 | +; input HI images are asumed to be in units of K*km/s | ||
33 | +; EXAMPLES | ||
34 | +; phangs_make_hi_images,source_name='ngc0628',/save,/show,/nostop | ||
35 | +; MODIFICATION HISTORY: | ||
36 | +; Written by J.-Ph. Bernard (2023) | ||
37 | +; Evolution details on the DustEMWrap gitlab. | ||
38 | +; See http://dustemwrap.irap.omp.eu/ for FAQ and help. | ||
39 | +;- | ||
40 | + | ||
41 | +IF keyword_set(help) THEN BEGIN | ||
42 | + doc_library,'phangs_make_hi_images' | ||
43 | + goto,the_end | ||
44 | +ENDIF | ||
45 | + | ||
46 | +win=0L | ||
47 | +dustem_define_la_common | ||
48 | + | ||
49 | +use_source_name='ngc0628' | ||
50 | +IF keyword_set(source_name) THEN use_source_name=source_name | ||
51 | + | ||
52 | +save_data_dir=!phangs_data_dir+'/ISRF/WORK/' | ||
53 | +file=save_data_dir+use_source_name+'_ref_header.sav' | ||
54 | +restore,file,/verb | ||
55 | +;% RESTORE: Restored variable: HREF. | ||
56 | + | ||
57 | +Nx=sxpar(href,'NAXIS1') | ||
58 | +Ny=sxpar(href,'NAXIS2') | ||
59 | + | ||
60 | +data_dir=!phangs_data_dir+'/phangs_drive/PHANGS_HI/' | ||
61 | + | ||
62 | +file=data_dir+use_source_name+'_21cm_strictmask_mom0.fits' | ||
63 | +d=readfits(file,h) | ||
64 | +;stop | ||
65 | +;sxaddpar,h,'CTYPE1','RA---TAN' | ||
66 | +;sxaddpar,h,'CTYPE2','RA---TAN' | ||
67 | +sxaddpar,h,'EQUINOX',2000. | ||
68 | +ind=where(finite(d) NE 1,count) | ||
69 | +IF count NE 0 THEN d[ind]=la_undef() | ||
70 | +IF sxpar(h,'NAXIS1') NE Nx OR sxpar(h,'NAXIS2') NE Ny THEN WHI=project2(h,d,href,/silent) ELSE WHI=d | ||
71 | +fact=1.83e18/1.e21 | ||
72 | +NHI=la_mul(WHI,fact) ;NH from HI in 1e21 H/cm2 | ||
73 | +tit=source_name+' '+'NHI [1e21 H/cm2]' | ||
74 | +;stop | ||
75 | +IF keyword_set(show_images) THEN BEGIN | ||
76 | + window,win & win=win+1 | ||
77 | + image_cont20,NHI,href,/square,imrange=[-0.1,5],image_color_table='jpbloadct',/silent,tit=tit,axis_color_table=1 | ||
78 | + IF not keyword_set(nostop) THEN stop | ||
79 | +ENDIF | ||
80 | + | ||
81 | +IF keyword_set(save) THEN BEGIN | ||
82 | + save_file=save_data_dir+use_source_name+'_HI_images.sav' | ||
83 | + save,NHI,href,file=save_file | ||
84 | + message,'Saved '+save_file,/continue | ||
85 | +ENDIF | ||
86 | + | ||
87 | +the_end: | ||
88 | + | ||
89 | +END | ||
0 | \ No newline at end of file | 90 | \ No newline at end of file |
@@ -0,0 +1,88 @@ | @@ -0,0 +1,88 @@ | ||
1 | +PRO phangs_make_isrf_product,source_name,voronoi_id,ISRFS,G0s,object_distance,object_thickness,help=help | ||
2 | + | ||
3 | +;+ | ||
4 | +; NAME: | ||
5 | +; phangs_make_isrf_product | ||
6 | +; CALLING SEQUENCE: | ||
7 | +; phangs_make_isrf_product,source_name,voronoi_id,ISRFS,G0s,object_distance,object_thickness,help=help | ||
8 | +; PURPOSE: | ||
9 | +; make and saves an ISRF product fits file | ||
10 | +; INPUTS: | ||
11 | +; source_name,voronoi_id,ISRFS,G0s,object_distance,object_thickness,help=help | ||
12 | +; OPTIONAL KEYWORDS: | ||
13 | +; save = if set, save the classes | ||
14 | +; help = if set, print this help | ||
15 | +; OUTPUTS: | ||
16 | +; None | ||
17 | +; OPTIONAL INPUT: | ||
18 | +; | ||
19 | +; OPTIONAL OUTPUT: | ||
20 | +; None | ||
21 | +; PROCEDURE AND SUBROUTINE USED | ||
22 | +; ISRF saved is the one predicted by dustem_plugin_phangs_stellar_isrf for each Muse Voronoi bin, | ||
23 | +; scaled in amplitude to match the Muse filter data for that Voronoi bin. | ||
24 | +; The G0 value computed is wrt the Mathis field at 1 mic. | ||
25 | +; SIDE EFFECTS: | ||
26 | +; produces file _isrf_min_prediction.fits | ||
27 | +; EXAMPLE: | ||
28 | +; phangs_make_isrf_product,'ngc0628' | ||
29 | +; MODIFICATION HISTORY: | ||
30 | +; written by Jean-Philippe Bernard | ||
31 | +;- | ||
32 | + | ||
33 | +IF keyword_set(help) THEN BEGIN | ||
34 | + doc_library,'phangs_make_isrf_product' | ||
35 | + goto,the_end | ||
36 | +ENDIF | ||
37 | + | ||
38 | +dustem_init | ||
39 | + | ||
40 | +data_dir=!phangs_data_dir+'/ISRF/WORK/' | ||
41 | +file=data_dir+source_name+'_isrf_min_prediction.sav' | ||
42 | +restore,file,/verb | ||
43 | +;% RESTORE: Restored variable: ISRFS. | ||
44 | +;% RESTORE: Restored variable: G0S. | ||
45 | +;% RESTORE: Restored variable: OBJECT_DISTANCE. | ||
46 | +;% RESTORE: Restored variable: OBJECT_THICKNESS. | ||
47 | +;% RESTORE: Restored variable: SOURCE_NAME. | ||
48 | + | ||
49 | +data_dir=!phangs_data_dir+'/ISRF/PRODUCTS/' | ||
50 | +file_save=data_dir+source_name+'_isrf_min_prediction.fits' | ||
51 | + | ||
52 | +lambir=dustem_get_wavelengths(isrf_wavelengths=isrf_wavelengths) | ||
53 | + | ||
54 | +Nvor=(size(ISRFS))[2] | ||
55 | +one_st={vid:0L,ISRF:ISRFS[*,0]} | ||
56 | +st_isrf=replicate(one_st,Nvor) | ||
57 | +st_wave={wavelength:isrf_wavelengths} | ||
58 | +FOR i=0L,Nvor-1 DO BEGIN | ||
59 | + st_isrf[i].vid=i | ||
60 | + st_isrf[i].ISRF=ISRFS[*,i] | ||
61 | +ENDFOR | ||
62 | +mwrfits,st_wave,file_save,/create | ||
63 | + | ||
64 | +dd0=mrdfits(file_save,0,h0) | ||
65 | + | ||
66 | +mwrfits,st_isrf,file_save | ||
67 | + | ||
68 | +;==== check reading the file | ||
69 | +dd1=mrdfits(file_save,1,h1) | ||
70 | +dd2=mrdfits(file_save,2,h2) | ||
71 | + | ||
72 | +;==== add info to the headers | ||
73 | +sxaddpar,h1,'PRODUCT','PHANGS ISRF' | ||
74 | +sxaddpar,h1,'OBJECT',source_name | ||
75 | +sxaddpar,h2,'PRODUCT','PHANGS ISRF' | ||
76 | +sxaddpar,h2,'OBJECT',source_name | ||
77 | + | ||
78 | +;==== rewrite file (with modified headers) | ||
79 | +mwrfits,st_wave,file_save,h1,/create | ||
80 | +mwrfits,st_isrf,file_save,h2 | ||
81 | + | ||
82 | +message,'Saved '+file_save,/continue | ||
83 | + | ||
84 | +stop | ||
85 | + | ||
86 | +the_end: | ||
87 | + | ||
88 | +END | ||
0 | \ No newline at end of file | 89 | \ No newline at end of file |