Blame view

src/idl/dustem_compute_polext.pro 6.25 KB
283845da   Ilyes Choubani   Small corrections...
1
2
FUNCTION dustem_compute_polext ,p_dim,$
sti=sti,$
3f93c873   Ilyes Choubani   correcting "compu...
3
4
5
POLEXT_spec=POLEXT_spec,$
SPEXT_spec=SPEXT_spec,$
dustem_fpolext=dustem_fpolext,$
07a51917   Ilyes Choubani   updating help sec...
6
7
8
9
dustem_ext=dustem_ext,$
out_st=out_st,$
_extra=extra,
help=help
e7938fa3   Ilyes Choubani   Corrected02: Impl...
10

07a51917   Ilyes Choubani   updating help sec...
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
;+
; NAME:
;    dustem_compute_polext
; PURPOSE:
;    Computes Polarized Extinction in units of optical depth for a given Dustem spectrum
; CATEGORY:
;    Dustem
; CALLING SEQUENCE:
;    polext=dustem_compute_polext(p_dim[,sti=][,polext_spec=][,spext_spec=][,dustem_fpolext=][,dustem_ext=][,out_st=][,_extra=][,/help])
; INPUTS:
;    p_dim      = parameter values
; OPTIONAL INPUT PARAMETERS:
;    st        = Dustem output structure
;    dustem_ext      = Computed polarized extinction for spectrum points in !dustem_data
; OUTPUTS:
;    ext       = computed EXT for spectrum points in !dustem_data 
; OPTIONAL OUTPUT PARAMETERS:
;    out_st      = Dustem output structure
;    polext_spec = Dustem polarized extiction output 
;    spext_spec  = Dustem polarized exinction fraction
;    dustem_fpolext  = Computed polarized extinction fraction for spectrum points in !dustem_data 
; ACCEPTED KEY-WORDS:
;    help      = If set, print this help
; COMMON BLOCKS:
;    None
; SIDE EFFECTS:
;    None
; RESTRICTIONS:
;    The dustem idl wrapper must be installed
;-
e7938fa3   Ilyes Choubani   Corrected02: Impl...
41
42


07a51917   Ilyes Choubani   updating help sec...
43
44
45
46
47
48

IF keyword_set(help) THEN BEGIN
  doc_library,'dustem_compute_polext'
  dustem_polext=0.
  goto,the_end
ENDIF
e7938fa3   Ilyes Choubani   Corrected02: Impl...
49
50

IF not keyword_set(sti) THEN BEGIN
f2caf3f1   Ilyes Choubani   Debugging some er...
51
52
  dustem_activate_plugins,p_dim/(*(*!dustem_fit).param_init_values),sti
  
e7938fa3   Ilyes Choubani   Corrected02: Impl...
53
54
ENDIF

e7938fa3   Ilyes Choubani   Corrected02: Impl...
55

b74c4452   Ilyes Choubani   Treating extincti...
56
57
POLEXT_spec = sti.polext.ext_tot * (*!dustem_HCD)/1.0e21  ; 

4b745987   Ilyes Choubani   minor update
58
;Hard-coded test to set to potential zero negative values in the polarized extinction arrays:
f2caf3f1   Ilyes Choubani   Debugging some er...
59
60
61
62
63
;so far this has been seen in absorption arrays  
;This test needs to include all grain species that polarize

IF !run_pol THEN BEGIN
    
f2caf3f1   Ilyes Choubani   Debugging some er...
64
65
66
67
68
69
    ind_ngtv_plxt = where (POLEXT_spec LT 0, ct_ngtv_plxt)
   
    IF ct_ngtv_plxt NE 0 THEN (POLEXT_spec)[ind_ngtv_plxt] = 0.
        
        
ENDIF 
b74c4452   Ilyes Choubani   Treating extincti...
70

afde94a3   Ilyes Choubani   general update
71
EXT_spec = sti.ext.ext_tot * (*!dustem_HCD)/1.0e21   ;This is Total intensity I
67bd858a   Ilyes Choubani   Replication of th...
72
73
74
75
76
77
78

out=0.
Nwaves=(size(POLEXT_spec))[1]

frac=POLEXT_spec/EXT_spec
tes=where(finite(frac) eq 0)
frac(tes)=0.
b74c4452   Ilyes Choubani   Treating extincti...
79

afde94a3   Ilyes Choubani   general update
80

b74c4452   Ilyes Choubani   Treating extincti...
81
82
scopes=tag_names((*!dustem_plugin))
IF scopes[0] NE 'NONE' THEN BEGIN
afde94a3   Ilyes Choubani   general update
83
84
85
86
87
88
89
90
;IF ptr_valid(!dustem_plugin) THEN BEGIN
  for i=0L,n_tags(*!dustem_plugin)-1 do begin
    if total(strsplit((*(*!dustem_plugin).(i).scope),'+',/extract) eq 'ADD_EXT') then EXT_spec+=(*(*!dustem_plugin).(i).spec)[*,0]
  endfor
ENDIF


IF scopes[0] NE 'NONE' THEN BEGIN
67bd858a   Ilyes Choubani   Replication of th...
91
92
93
94
95
96
97

    FOR i=0L,n_tags(*!dustem_plugin)-1 DO BEGIN   
        
        IF total(strsplit((*(*!dustem_plugin).(i).scope),'+',/extract) EQ 'REPLACE_POLEXT') THEN BEGIN
            
            QEXT_spec=(*(*!dustem_plugin).(i).spec)[*,1]
            UEXT_spec=(*(*!dustem_plugin).(i).spec)[*,2]
67bd858a   Ilyes Choubani   Replication of th...
98
99
100
            
        ENDIF 
        
887b421b   Ilyes Choubani   correcting some c...
101
102
    ENDFOR   
ENDIF 
67bd858a   Ilyes Choubani   Replication of th...
103
104
105
106
107
    
    IF ~isa(QEXT_spec) && ~isa(UEXT_spec) THEN BEGIN
        polar_ippsi2iqu,EXT_spec,QEXT_spec,UEXT_spec,frac,replicate(!dustem_psi_ext,Nwaves)
        SPEXT_spec = frac 
    ENDIF
887b421b   Ilyes Choubani   correcting some c...
108
109
110

IF scopes[0] NE 'NONE' THEN BEGIN

67bd858a   Ilyes Choubani   Replication of th...
111
112
113
114
115
116
    FOR i=0L,n_tags(*!dustem_plugin)-1 DO BEGIN
        
        IF total(strsplit((*(*!dustem_plugin).(i).scope),'+',/extract) EQ 'ADD_POLEXT') THEN BEGIN
        
            QEXT_spec+=(*(*!dustem_plugin).(i).spec)[*,1]
            UEXT_spec+=(*(*!dustem_plugin).(i).spec)[*,2]
67bd858a   Ilyes Choubani   Replication of th...
117
118
119
120
            
        ENDIF
      
    ENDFOR
67bd858a   Ilyes Choubani   Replication of th...
121

887b421b   Ilyes Choubani   correcting some c...
122
123
124
ENDIF    

POLEXT_spec=sqrt(QEXT_spec^2+UEXT_spec^2)
afde94a3   Ilyes Choubani   general update
125
SPEXT_spec = POLEXT_SPEC/EXT_spec
887b421b   Ilyes Choubani   correcting some c...
126

e7938fa3   Ilyes Choubani   Corrected02: Impl...
127

0068116a   Ilyes Choubani   General update + ...
128
dustem_polext = (*(*!dustem_data).qext).values * 0.
67bd858a   Ilyes Choubani   Replication of th...
129
130
131
132
133
134
135
136
137
138
139
140
141

    
if not isarray(POLEXT_spec) THEN stop ;I don't understand this test. The only thing it can indicate is a problem with the dust parameters or the fortran executable. But in my opinion these tests would be  


;NO COLOR CORRECTION FOR EXTINCTION. FOR NOW ...

; IF !dustem_do_cc NE 0 AND !dustem_never_do_cc EQ 0 THEN BEGIN
;   message,'DOING color correction calculations',/info
; ENDIF ELSE BEGIN
;   message,'SKIPPING color correction calculations',/info
; ENDELSE
; 
0068116a   Ilyes Choubani   General update + ...
142
; ind_polsed=where((*(*!dustem_data).qsed).filt_names NE 'SPECTRUM',count_polsed)  
67bd858a   Ilyes Choubani   Replication of th...
143
144
;   
; IF count_polsed NE 0 THEN BEGIN
0068116a   Ilyes Choubani   General update + ...
145
;   filter_names=((*(*!dustem_data).qsed).filt_names)(ind_polsed)
67bd858a   Ilyes Choubani   Replication of th...
146
147
148
149
150
151
152
153
154
155
;   spolsed=dustem_cc(st.polsed.wav,P_spec,filter_names,cc=cc)
;   dustem_polsed[ind_polsed]=spolsed
; ENDIF


;For spectrum data points, interpolate in log-log.
;Linear interpolation leads to wrong values, in particular where few
;wavelengths points exist in the model (long wavelengths).
;I believe this to be automatic because the provided dustem spectra are already sampled on a log-log grid.

0068116a   Ilyes Choubani   General update + ...
156
157
ind_spec=where((*(*!dustem_data).qext).filt_names EQ 'SPECTRUM',count_spec) 
IF count_spec NE 0 THEN dustem_polext(ind_spec)=interpol(POLEXT_spec,sti.polext.wav,(((*(*!dustem_data).qext).wav)(ind_spec)))
67bd858a   Ilyes Choubani   Replication of th...
158

afde94a3   Ilyes Choubani   general update
159
out_st=sti
67bd858a   Ilyes Choubani   Replication of th...
160
161
162
163
164

;GENERATING THE INTERPOLATES FOR POLFRAC (dustem_polfrac)
if !run_lin then begin
      		
    
afde94a3   Ilyes Choubani   general update
165
    if not keyword_set(dustem_ext) then dustem_ext = dustem_compute_ext(p_dim,sti,EXT_spec) 
67bd858a   Ilyes Choubani   Replication of th...
166
167
168
169
170
171
172
173
174
175
176
177
    
    If n_elements(dustem_ext) ne n_elements(dustem_polext) then begin                            
        if n_elements(dustem_ext) gt n_elements(dustem_polext) then begin 
      
            dustem_polext_x = dustem_polext
            dustem_ext_x = dustem_polext ;meaning dustem_sed needs to be modified
      
            nwaves = n_elements(dustem_polext)
      
      
              for i=0L,nwaves-1 do begin
      
0068116a   Ilyes Choubani   General update + ...
178
                  j=where((*(*!dustem_data).ext).wav EQ (*(*!dustem_data).fpolext).wav(i),testwav)
67bd858a   Ilyes Choubani   Replication of th...
179
180
181
182
183
184
185
186
187
188
189
190
                  if testwav ne 0 then dustem_ext_x(i) = dustem_ext(j(0))                                    
      
              endfor
      
        endif ELSE begin
        
            dustem_polext_x = dustem_ext
            dustem_ext_x = dustem_ext ;meaning dustem_polsed needs to be modified
        
            nwaves = n_elements(dustem_ext)
        
            for i=0L,nwaves-1 do begin
0068116a   Ilyes Choubani   General update + ...
191
                j=where((*(*!dustem_data).ext).wav EQ (*(*!dustem_data).fpolext).wav(i),testwav)
67bd858a   Ilyes Choubani   Replication of th...
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
                if testwav ne 0 then dustem_polext_x(i) = dustem_polext(j(0))                                    
            endfor
          
        
        ENDELSE
    
    endif ELSE BEGIN
        
        dustem_polext_x = dustem_polext 
        dustem_ext_x = dustem_ext
    
    ENDELSE
    
    dustem_fpolext = dustem_polext_x/dustem_ext_x 
	       
ENDIF
e7938fa3   Ilyes Choubani   Corrected02: Impl...
208

e7938fa3   Ilyes Choubani   Corrected02: Impl...
209
210
211
return, dustem_polext


759a527d   Ilyes Choubani   general update
212

e7938fa3   Ilyes Choubani   Corrected02: Impl...
213
END