Blame view

src/idl/dustemwrap_plot.pro 28.4 KB
5f04fa07   Ilyes Choubani   general update
1
PRO dustemwrap_plot,p_dim,st,dustem_sed,SED_spec,dustem_qsed,Q_spec,dustem_used,U_spec,dustem_polsed,P_spec,dustem_polfrac,SP_spec,dustem_psi_em,PSI_spec,_extra=_extra 
2910e8ce   Ilyes Choubani   Draft version of ...
2

40597848   Ilyes Choubani   Plotting of numbe...
3
;This is also necessary for the plotting of the results of the fit (Last iteration) 
2910e8ce   Ilyes Choubani   Draft version of ...
4
5
6
IF not keyword_set(st) THEN BEGIN
  ;Activation of the plugins is needed because of the plotting of the total emission model that includes them. 
  dustem_activate_plugins,p_dim/(*(*!dustem_fit).param_init_values)  ; 0/0 division case?
5f04fa07   Ilyes Choubani   general update
7
  st=dustem_run(p_dim)
fcb6eade   Ilyes Choubani   general update - ...
8
9
10
11
12
13
  dustem_sed = dustem_compute_sed(p_dim,st,SED_spec)
  
  if !run_pol && !run_lin then begin
      
      dustem_polsed = dustem_compute_polsed(p_dim,st,P_spec,SP_spec,dustem_polfrac)
      toto = dustem_compute_stokes(p_dim,st,dustem_qsed,dustem_used,Q_spec,U_spec,PSI_spec,dustem_psi_em) 
40597848   Ilyes Choubani   Plotting of numbe...
14
      ;This is for emission but what about extinction...
fcb6eade   Ilyes Choubani   general update - ...
15
16
17
      
  endif  
   
40597848   Ilyes Choubani   Plotting of numbe...
18
19
20
21
22
23
24
25
26
27
28
29
ENDIF ELSE BEGIN ;st is provided 
    
        dustem_sed = dustem_compute_sed(p_dim,st,SED_spec)
    
    if !run_pol && !run_lin then begin
        
        dustem_polsed = dustem_compute_polsed(p_dim,st,P_spec,SP_spec,dustem_polfrac)
        toto = dustem_compute_stokes(p_dim,st,dustem_qsed,dustem_used,Q_spec,U_spec,PSI_spec,dustem_psi_em) 
        
        ;This is for emission but what about extinction...
            
    endif
2910e8ce   Ilyes Choubani   Draft version of ...
30

40597848   Ilyes Choubani   Plotting of numbe...
31
ENDELSE 
dfc68a85   Ilyes Choubani   Fixed some plotti...
32
33


2910e8ce   Ilyes Choubani   Draft version of ...
34
35
36
37
38
39
;if ~windowavailable(cgquery()) then begin

;LIST OF TESTS THAT NEED TO BE RAN SO THAT THE PLOTTING OF THE MODEL SPECTRA OCCURS

test_sed = isa(!dustem_show.sed)
test_ext = isa(!dustem_show.ext)
b5314324   Ilyes Choubani   updating the plot...
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
if !run_pol then begin
    test_polext = isa(!dustem_show.polext)
    test_polsed = isa(!dustem_show.polsed)
    test_polfrac = isa(!dustem_show.polfrac)
    test_psi_em = isa(!dustem_show.psi_em)
    test_psi_ext = isa(!dustem_show.psi_ext)
    test_qsed = isa(!dustem_show.qsed)
    test_used = isa(!dustem_show.used)
    test_qext = isa(!dustem_show.qext)
    test_uext = isa(!dustem_show.uext)
    test_m = test_sed or test_polsed or test_polfrac or test_qsed or test_used or test_psi_em
    test_x = test_ext or test_polext or test_qext or test_uext or test_psi_ext
endif else begin
    test_m = test_sed 
    test_x = test_ext 
endelse
18e4331f   Ilyes Choubani   general update (f...
56

2910e8ce   Ilyes Choubani   Draft version of ...
57
;testing on the fitting of emission vs extinction data
2910e8ce   Ilyes Choubani   Draft version of ...
58

b5314324   Ilyes Choubani   updating the plot...
59
n_plgns = n_tags(*!dustem_plugin)
2910e8ce   Ilyes Choubani   Draft version of ...
60

5f04fa07   Ilyes Choubani   general update
61
62
63
64
frmt0='(A36)'
frmt1='(1E10.2)'
frmt2='(10F10.2)'

2910e8ce   Ilyes Choubani   Draft version of ...
65
66
67
;I have decided to keep track of the command index manually as I did not find any command online that does this.
cmdind_m = 0 ;for emission
cmdind_x = 0 ;for extinction
5f04fa07   Ilyes Choubani   general update
68
69
70
;trying to do the same thing for parameters and plugins
cmdind_prms = 0 ;for parameters
cmdind_plgns = 0 ;for plugins
2910e8ce   Ilyes Choubani   Draft version of ...
71

2910e8ce   Ilyes Choubani   Draft version of ...
72
;ADDING PLUGIN(S) TO SPECTRUM----------------
2910e8ce   Ilyes Choubani   Draft version of ...
73
74
75
76

;these following indices will be used to change the keep the same information in the _extra structure
;this is an initial solution until I finish coding the _extra-filtering procedure. 

2910e8ce   Ilyes Choubani   Draft version of ...
77
78
79
iswinsed = !dustemcgwin_id.sed EQ la_undef()
iswinext = !dustemcgwin_id.ext EQ la_undef()

5f04fa07   Ilyes Choubani   general update
80
81
82
83
84
85
86
;trying to do the same thing for parameters and plugins
;But we need to know if the extinction or the emission mode is on.
;so the use of ths pointer will be different than the others
iswinprms = !dustemcgwin_id.prms EQ la_undef()
iswinplgns = !dustemcgwin_id.plgns EQ la_undef()


18e4331f   Ilyes Choubani   general update (f...
87
88
89
;plotstrct = !p
degtorad = !pi/180 ;factor that the arctan will be devided by in order to have an axis in degrees. Talk to JP maybe he wants angle in radians.

5f04fa07   Ilyes Choubani   general update
90
91
92
93
;I think I will test over the presence of the errors because they are not computed at that point.

;errors = ((*!dustem_fit).current_param_errors)
if isa((*!dustem_fit).current_param_errors) then begin
fcb6eade   Ilyes Choubani   general update - ...
94
    errors = (*(*!dustem_fit).current_param_errors) * (*(*!dustem_fit).param_init_values)
5f04fa07   Ilyes Choubani   general update
95
endif else begin
dfc68a85   Ilyes Choubani   Fixed some plotti...
96
    errors = (*(*!dustem_fit).param_init_values)*0.;+la_undef();Initialized to 0 instead of la_undef() 
5f04fa07   Ilyes Choubani   general update
97
98
99
100
101
102
103
104
105
106
107
108
109
110
ENDELSE 

if isa((*!dustem_fit).chi2) then begin
    chi2 = (*!dustem_fit).chi2    
endif else begin
    chi2 = la_undef();maybe not the best initialization 
endelse 

if isa((*!dustem_fit).rchi2) then begin
    rchi2 = (*!dustem_fit).rchi2    
endif else begin
    rchi2 = la_undef();maybe not the best initialization 
endelse 

707e83c5   Ilyes Choubani   updating dustewra...
111

fcb6eade   Ilyes Choubani   general update - ...
112
if isa(p_dim) then begin
dfc68a85   Ilyes Choubani   Fixed some plotti...
113
114
115
116
117
118
119
120
121
122
    
    if isa((*!dustem_fit).current_param_values) then begin
        
        res  = (*(*!dustem_fit).current_param_values) 
        
    endif else begin  
    
        res = p_dim    
    
    endelse
fcb6eade   Ilyes Choubani   general update - ...
123
124
endif else begin
    
dfc68a85   Ilyes Choubani   Fixed some plotti...
125
   res = (*(*!dustem_fit).param_init_values)*0.;+la_undef()
fcb6eade   Ilyes Choubani   general update - ...
126
127
    
endelse
2910e8ce   Ilyes Choubani   Draft version of ...
128
129
130

;if iswinsed then begin ;I believe the iswin test should be below the case condition because I am not copying all the first 'HUGE LOOP' but rather replacing the positional arrays.            
if test_m then begin
2910e8ce   Ilyes Choubani   Draft version of ...
131
132
133
    ;Generating emission window and saving window ID
    
    if iswinsed then begin
dfc68a85   Ilyes Choubani   Fixed some plotti...
134
        
af5bca1f   Ilyes Choubani   general update
135
        if !run_pol then cgwindow,wxsize=910,wysize=658,wtitle='DUSTEMWRAP v2.0 (EMISSION)' else cgwindow, wtitle='DUSTEMWRAP v2.0 (EMISSION)';, wback='grey';,wobject=winobj_m
2910e8ce   Ilyes Choubani   Draft version of ...
136
137
138
        winid_m = cgquery(dimensions=dim_m,/current) ;this has to be changed because the dimensions of this array change with the data sets present (extinction/emission).
        !dustemcgwin_id.sed = winid_m
        
5f04fa07   Ilyes Choubani   general update
139
140
141
142
143
144
        cgcontrol, winid_m, execute=0
        ;cgset, winid_m
        ;Plotting model string (legend)
        xxpos = 0.015
        yypos = 0.97
        ;Plotting Hydrogen column density string (legend)
abebbdf3   Ilyes Choubani   General update: A...
145
        cgtext, xxpos, yypos,'Model : '+!dustem_model,color=0,/normal,charsize = 1.2,/addcmd ;& cmdind_m+=1 This is the first command in the window
5f04fa07   Ilyes Choubani   general update
146
        yypos = 0.95
abebbdf3   Ilyes Choubani   General update: A...
147
        cgtext, xxpos, yypos,textoidl('N_{H}')+textoidl(' (H/cm^2) : ')+strmid(string(*!dustem_HCD,format='(1E10.2)'),2),color=0,/normal,charsize = 1.2,/addcmd & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
148
        
40597848   Ilyes Choubani   Plotting of numbe...
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
        ;Plotting of the number of iterations completed by the fitter
        
        ;Plotting of the number of runs
        ;Getting the width of the unrefreshed string
        widthtot=0.
        cgtext, xxpos, yypos,'Runs : ',color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtext = thiswidth
        widthtot+= thiswidth ;fixed width
        !dustemcgwin_ncmds.runs.txtwdth = thiswidth
        
        ;Getting the width of the refreshed string
        cgtext, xxpos, yypos,strtrim(!dustem_iter.act,2),color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtot+= thiswidth;varying width        
        
        ;These two lines will also have to      be modified when plotting the refreshed values
        xxpos = 0.015 ;1.0 - widthtot - 0.03
        yypos = 0.015
        
        ;Displaying fixed part
        cgtext, xxpos, yypos,'Runs : ',color=0,/normal,charsize = 1.35,/addcmd & cmdind_m+=1
        ;Displaying refreshed part (first run . This is the command that will be replaced)
        cgtext, xxpos + widthtext + 0.015 , yypos,strtrim(!dustem_iter.act,2),color=0,/normal,charsize = 1.0,/addcmd & cmdind_m+=1
        ;saving the command id to replace it
        !dustemcgwin_ncmds.runs.pl = cmdind_m

5f04fa07   Ilyes Choubani   general update
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
        ;plotting of (mostly) fixed data for rchi2
        ;Since the format of the strings is specified, the length/width of the string in thex direction is fixed. 
        
        
        ;Getting the width of the unrefreshed string
        widthtot=0.
        cgtext, xxpos, yypos,textoidl('\chi^{2} : '),color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtext = thiswidth
        widthtot+= thiswidth ;fixed width
        
        ;Getting the width of the refresh.ed string
        cgtext, xxpos, yypos,strtrim(string(chi2,format=frmt2),2),color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtot+= thiswidth;varying width        
        ;saving the command string width to replace it
        !dustemcgwin_ncmds.chi2.txtwdth = thiswidth
        
        
abebbdf3   Ilyes Choubani   General update: A...
191
        xxpos = 1.0 - widthtot - 0.03
5f04fa07   Ilyes Choubani   general update
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
        
        yypos = 0.97
        
        ;Displaying fixed part
        cgtext, xxpos, yypos,textoidl('\chi^{2} : '),color=0,/normal,charsize = 1.0,/addcmd & cmdind_m+=1
        ;Displaying refreshed part (first run . This is the command that will be replaced)
        
        cgtext, xxpos + widthtext , yypos,strtrim(string(chi2,format=frmt2),2),color=0,/normal,charsize = 1.0,/addcmd & cmdind_m+=1
       
        ;saving the command id to replace it
        !dustemcgwin_ncmds.chi2.pl = cmdind_m
 
        
        
        ;plotting of (mostly) fixed data for rchi2
        
        ;Getting the width of the unrefreshed string
        widthtot=0.
        cgtext, xxpos, yypos,textoidl('r_{\chi^{2}} : '),color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtext = thiswidth
        widthtot+= thiswidth ;fixed width
        ;!dustemcgwin_ncmds.rchi2.txtwdth1 = thiswidth
        ;Getting the width of the refreshed string
        cgtext, xxpos, yypos,strtrim(string(rchi2,format=frmt2),2),color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtot+= thiswidth;varying width        
        !dustemcgwin_ncmds.rchi2.txtwdth = thiswidth
        ;These two lines will also have to      be modified when plotting the refreshed values
abebbdf3   Ilyes Choubani   General update: A...
219
        xxpos = 1.0 - widthtot - 0.03
5f04fa07   Ilyes Choubani   general update
220
221
222
223
224
225
226
227
228
229
        yypos = 0.95
        
        ;Displaying fixed part
        cgtext, xxpos, yypos,textoidl('r_{\chi^{2}} : '),color=0,/normal,charsize = 1.35,/addcmd & cmdind_m+=1
        ;Displaying refreshed part (first run . This is the command that will be replaced)
        cgtext, xxpos + widthtext , yypos,strtrim(string(rchi2,format=frmt2),2),color=0,/normal,charsize = 1.0,/addcmd & cmdind_m+=1
        ;saving the command id to replace it
        !dustemcgwin_ncmds.rchi2.pl = cmdind_m
        
        
5f04fa07   Ilyes Choubani   general update
230
231
        ;Plotting of the title of the dashboard (plot(s))
        
5f04fa07   Ilyes Choubani   general update
232
        ;Getting the width of the title 
dfc68a85   Ilyes Choubani   Fixed some plotti...
233
234
235
236
        tit=string(_extra.title);
    
        cgtext, 0.3, 0.95,tit+' (RUNNING)',color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1
        widthtot = thiswidth
5f04fa07   Ilyes Choubani   general update
237
238
        xxpos = (1 - thiswidth)/2
        yypos = 0.96
dfc68a85   Ilyes Choubani   Fixed some plotti...
239
240
241
242
        
        cgtext, 0.3, 0.95,tit,color=0,/normal,charsize=-1,width=thiswidth,/addcmd & cmdind_m+=1 
        !dustemcgwin_ncmds.pltit.txtwdth = thiswidth*1.6 + (1 - widthtot)/2
         
5f04fa07   Ilyes Choubani   general update
243
        cgtext, xxpos, yypos,tit,color=0,/normal,charsize = 1.6,/addcmd & cmdind_m+=1
dfc68a85   Ilyes Choubani   Fixed some plotti...
244
245
        xxpos+=thiswidth*1.6
        cgtext, xxpos, yypos,' (RUNNING)',color=0,/normal,charsize = 1.6,/addcmd & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
246
247
248
249
        
        !dustemcgwin_ncmds.pltit.pl = cmdind_m
        
    endif else begin 
2910e8ce   Ilyes Choubani   Draft version of ...
250
    
5f04fa07   Ilyes Choubani   general update
251
252
253
254
255
256
257
        
        winid_m = !dustemcgwin_id.sed
        cgcontrol, winid_m, execute=0
        cgset, winid_m ;apparently specifying the window index isn't enough. This might be because of the use of cgcontrol
        
        ;Refreshing chi2 data: 
        cmdin_m = !dustemcgwin_ncmds.chi2.pl
abebbdf3   Ilyes Choubani   General update: A...
258
        xxpos = 1 - !dustemcgwin_ncmds.chi2.txtwdth - 0.03  
5f04fa07   Ilyes Choubani   general update
259
260
261
262
263
264
265
        yypos = 0.97
        cgwindow,'cgtext', xxpos , yypos,strtrim(string(chi2,format=frmt2),2),color=0,/normal,charsize = 1.0,/replacecmd,cmdindex=cmdin_m, winid=winid_m ;& cmdind_m+=1
        
        
        
        ;Refreshing rchi2 data: 
        cmdin_m = !dustemcgwin_ncmds.rchi2.pl
abebbdf3   Ilyes Choubani   General update: A...
266
        xxpos = 1 - !dustemcgwin_ncmds.rchi2.txtwdth - 0.03  
5f04fa07   Ilyes Choubani   general update
267
268
        yypos = 0.95
        cgwindow,'cgtext', xxpos , yypos,strtrim(string(rchi2,format=frmt2),2),color=0,/normal,charsize = 1.0,/replacecmd,cmdindex=cmdin_m, winid=winid_m ;& cmdind_m+=1
40597848   Ilyes Choubani   Plotting of numbe...
269
270
271
272
273
274
275
276
277
        
        
        ;Refreshing number of runs data: 
        cmdin_m = !dustemcgwin_ncmds.runs.pl
        xxpos = 0.03 + !dustemcgwin_ncmds.runs.txtwdth*1.35  ;(because of charsize)
        yypos = 0.015
        cgwindow,'cgtext', xxpos , yypos,strtrim(!dustem_iter.act,2),color=0,/normal,charsize = 1.0,/replacecmd,cmdindex=cmdin_m, winid=winid_m ;& cmdind_m+=1
        
        
dfc68a85   Ilyes Choubani   Fixed some plotti...
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
         
        ;update of the title here ?
        
        if isa((*!dustem_fit).current_param_values) then begin
            ;replacing my count - 3
            tit=string(_extra.title)
            cmdin_m = !dustemcgwin_ncmds.pltit.pl
            
            xxpos = !dustemcgwin_ncmds.pltit.txtwdth
            yypos = 0.96
        
            cgwindow,'cgtext', xxpos , yypos,' (Final Run)',color=0,/normal,charsize = 1.6,/replacecmd,cmdindex=cmdin_m, winid=winid_m  
        
        endif
    
5f04fa07   Ilyes Choubani   general update
293
    endelse
2910e8ce   Ilyes Choubani   Draft version of ...
294
295
296
297
    
    ;cgWindow_GetDefs,xsize=xsize,ysize=ysize
    ;cgcontrol, resize=[xsize,ysize]
    if !run_pol then begin
c8368c6e   Ilyes Choubani   updating plotting...
298
        ;,wback='grey'
2910e8ce   Ilyes Choubani   Draft version of ...
299
300
        
        ;position arrays for plot and normalized graph
af5bca1f   Ilyes Choubani   general update
301
        
af5bca1f   Ilyes Choubani   general update
302
        ;THIS IS HARD-CODED IN A VERY SILLY WAY
2910e8ce   Ilyes Choubani   Draft version of ...
303
304
305
        
        p_sed = [0.05,0.67,0.475,0.90]
        p_psed = [0.525,0.67,0.95,0.90]
af5bca1f   Ilyes Choubani   general update
306
        p_spsed = [0.05,0.375,0.475,0.575]
18e4331f   Ilyes Choubani   general update (f...
307
        p_psised = [0.525,0.375,0.95,0.575]
5f04fa07   Ilyes Choubani   general update
308
        p_qsed = [0.05,0.12,0.475,0.35]  
18e4331f   Ilyes Choubani   general update (f...
309
310
        p_used = [0.525,0.12,0.95,0.35]
        
2910e8ce   Ilyes Choubani   Draft version of ...
311
        np_sed = [0.05,0.60,0.475,0.67]
18e4331f   Ilyes Choubani   general update (f...
312
313
314
        np_psed = [0.525,0.60,0.95,0.67]
        np_qsed = [0.05,0.05,0.475,0.12] 
        np_used = [0.525,0.05,0.95,0.12]
af5bca1f   Ilyes Choubani   general update
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
        
        p_sed[1]+= 0.0125 & p_sed[3]+= 0.0125 
        p_psed[1]+= 0.0125 & p_psed[3]+= 0.0125
        p_spsed[1]+= 0.0125 & p_spsed[3]+= 0.0125
        p_psised[1]+= 0.0125 & p_psised[3]+= 0.0125
        p_qsed[1]+= 0.0125 & p_qsed[3]+= 0.0125
        p_used[1]+= 0.0125 & p_used[3]+= 0.0125
        
        np_sed[1]+= 0.0125 & np_sed[3]+= 0.0125 
        np_psed[1]+= 0.0125 & np_psed[3]+= 0.0125
        np_qsed[1]+= 0.0125 & np_qsed[3]+= 0.0125
        np_used[1]+= 0.0125 & np_used[3]+= 0.0125
        
        
          
2910e8ce   Ilyes Choubani   Draft version of ...
330
331
332
    endif else begin
        p_sed  = [0.07,0.30,0.97,0.85]
        np_sed = [0.07,0.10,0.97,0.30]
c8368c6e   Ilyes Choubani   updating plotting...
333
    
2910e8ce   Ilyes Choubani   Draft version of ...
334
335
336
337
    endelse

    ;Plotting of sed data axes (whether or not data is present)
    plotsym,0,/fill ;you might need to execute this again. hmm...
5f04fa07   Ilyes Choubani   general update
338
339


bc224f3e   Ilyes Choubani   Update of plottin...
340
    ;This is not the right test the user might want to show the prediction for sed and fit the stokes parameters
2910e8ce   Ilyes Choubani   Draft version of ...
341
342
    if ~test_sed then begin ; SED data is not present (For completeness) # This is only valid when !run_pol=1
        
5f04fa07   Ilyes Choubani   general update
343
344
        cgwindow,'dustemcgwin_dataset', st, dataset='SED', /nodata, position=p_sed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
        cgwindow,'dustemcgwin_dataset', st, dataset='SED', /nodata, /norm, position=np_sed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
2910e8ce   Ilyes Choubani   Draft version of ...
345

2910e8ce   Ilyes Choubani   Draft version of ...
346
    endif else begin ;SED exists
18e4331f   Ilyes Choubani   general update (f...
347
348

       if  ~iswinsed then begin
5f04fa07   Ilyes Choubani   general update
349
       
18e4331f   Ilyes Choubani   general update (f...
350
           cmdind_m = !dustemcgwin_ncmds.sed.pl
5f04fa07   Ilyes Choubani   general update
351
352
           cgwindow,'dustemcgwin_dataset', st, dustem_sed,SED_spec,dataset='SED', /refresh ,position=p_sed, winid=winid_m,cmdindex=cmdind_m,/replacecmd,_extra=_extra     
           
18e4331f   Ilyes Choubani   general update (f...
353
           cmdind_m = !dustemcgwin_ncmds.sed.nrm
5f04fa07   Ilyes Choubani   general update
354
355
356
           cgwindow,'dustemcgwin_dataset', st, dustem_sed,SED_spec,dataset='SED', /norm, /refresh,position=np_sed, winid=winid_m,cmdindex=cmdind_m,/replacecmd,_extra=_extra
           
           
18e4331f   Ilyes Choubani   general update (f...
357
       endif else begin
5f04fa07   Ilyes Choubani   general update
358
359
360
      
           cgwindow,'dustemcgwin_dataset', st, dataset='SED', position=p_sed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1 
           cgwindow,'dustemcgwin_dataset', st, dustem_sed,SED_spec, dataset='SED', /refresh ,position=p_sed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
361
           !dustemcgwin_ncmds.sed.pl = cmdind_m
5f04fa07   Ilyes Choubani   general update
362
           
18e4331f   Ilyes Choubani   general update (f...
363
           cgwindow,'dustemcgwin_dataset', st, dataset='SED',/norm, position=np_sed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1 ;I think nodata can also be used too
5f04fa07   Ilyes Choubani   general update
364
365
           
           cgwindow,'dustemcgwin_dataset', st, dustem_sed,SED_spec, dataset='SED', /norm, /refresh,position=np_sed, /addcmd ,winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
366
           !dustemcgwin_ncmds.sed.nrm = cmdind_m
5f04fa07   Ilyes Choubani   general update
367
              
18e4331f   Ilyes Choubani   general update (f...
368
369
370
371
372
       endelse       
    endelse
    
    ;if ~!run_pol then begin;I don't think the order of the  ;goto, end_m
      if !run_pol then begin ;then goto, end_m
2910e8ce   Ilyes Choubani   Draft version of ...
373
        
18e4331f   Ilyes Choubani   general update (f...
374
375
376
        if ~test_qsed then begin ;Qsed is not present
            
            cgwindow,'dustemcgwin_dataset', st, dataset='QSED', /nodata, position=p_qsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
377
            cgwindow,'dustemcgwin_dataset', st, dataset='QSED', /nodata, /norm, position=np_qsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
c8368c6e   Ilyes Choubani   updating plotting...
378
        
18e4331f   Ilyes Choubani   general update (f...
379
380
381
382
383
        endif else begin ;Qsed data is present
               
            if  ~iswinsed then begin
                cmdind_m = !dustemcgwin_ncmds.qsed.pl
                ;refreshing the positive_only and negative_only plots if data is present in them
5f04fa07   Ilyes Choubani   general update
384
385
386
387
                cgwindow,'dustemcgwin_dataset', st, dustem_qsed,Q_spec,SED_spec,dataset='QSED',/positive_only, nodata=0, /refresh ,position=p_qsed, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
                
                cgwindow,'dustemcgwin_dataset', st, dustem_qsed,Q_spec,SED_spec, dataset='QSED',/negative_only, nodata=0, /refresh ,position=p_qsed, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
                
18e4331f   Ilyes Choubani   general update (f...
388
                cmdind_m = !dustemcgwin_ncmds.qsed.nrm
5f04fa07   Ilyes Choubani   general update
389
390
                cgwindow,'dustemcgwin_dataset', st, dustem_qsed,Q_spec,SED_spec, dataset='QSED', /refresh, nodata=0, /norm,position=np_qsed, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
                
18e4331f   Ilyes Choubani   general update (f...
391
            endif else begin
5f04fa07   Ilyes Choubani   general update
392
                
dfc68a85   Ilyes Choubani   Fixed some plotti...
393
                ;Plotting of postive values if they exist (if hidden data is present it is plotted if not an empty plot is rendered)
18e4331f   Ilyes Choubani   general update (f...
394
395
                cgwindow,'dustemcgwin_dataset', st, dataset='QSED', position=p_qsed, /addcmd, winid=winid_m,/positive_only, _extra=_extra & cmdind_m+=1
                ;Refreshing the positive_only plot ONLY if there is data. If not do nothing
5f04fa07   Ilyes Choubani   general update
396
                cgwindow,'dustemcgwin_dataset', st, dustem_qsed,Q_spec,SED_spec, dataset='QSED',/positive_only, /refresh ,position=p_qsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
397
398
399
                
                cgwindow,'dustemcgwin_dataset', st, dataset='QSED', position=p_qsed, /addcmd, winid=winid_m,/negative_only, _extra=_extra & cmdind_m+=1
                ;Refreshing the negative_only plot ONLY if there is data. If not do nothing
5f04fa07   Ilyes Choubani   general update
400
401
                cgwindow,'dustemcgwin_dataset', st, dustem_qsed,Q_spec,SED_spec,dataset='QSED',/negative_only, /refresh ,position=p_qsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
            
18e4331f   Ilyes Choubani   general update (f...
402
403
                !dustemcgwin_ncmds.qsed.pl = cmdind_m
                
5f04fa07   Ilyes Choubani   general update
404
                
18e4331f   Ilyes Choubani   general update (f...
405
                cgwindow,'dustemcgwin_dataset', st, dataset='QSED',/norm, position=np_qsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1 ;I think nodata can also be uqsed too
5f04fa07   Ilyes Choubani   general update
406
                cgwindow,'dustemcgwin_dataset', st, dustem_qsed,Q_spec,SED_spec,dataset='QSED', /norm, /refresh,position=np_qsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
407
                !dustemcgwin_ncmds.qsed.nrm = cmdind_m
5f04fa07   Ilyes Choubani   general update
408
                
18e4331f   Ilyes Choubani   general update (f...
409
410
        endelse       
      endelse
5f04fa07   Ilyes Choubani   general update
411
         ;stop        
18e4331f   Ilyes Choubani   general update (f...
412
413
414
        if ~test_used then begin ;used is not present
            
            cgwindow,'dustemcgwin_dataset', st, dataset='USED', /nodata, position=p_used, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
415
            cgwindow,'dustemcgwin_dataset', st, dataset='USED', /nodata, /norm, position=np_used, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
c8368c6e   Ilyes Choubani   updating plotting...
416
        
18e4331f   Ilyes Choubani   general update (f...
417
418
419
420
421
        endif else begin ;used data is present
               
            if  ~iswinsed then begin
                cmdind_m = !dustemcgwin_ncmds.used.pl
                ;refreshing the positive_only and negative_only plots if data is present in them
5f04fa07   Ilyes Choubani   general update
422
423
424
425
                cgwindow,'dustemcgwin_dataset', st, dustem_used,U_spec,SED_spec, dataset='USED',/positive_only, /refresh, nodata=0 ,position=p_used, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
                
                cgwindow,'dustemcgwin_dataset', st, dustem_used,U_spec,SED_spec, dataset='USED',/negative_only, /refresh, nodata=0 ,position=p_used, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
                
18e4331f   Ilyes Choubani   general update (f...
426
                cmdind_m = !dustemcgwin_ncmds.used.nrm
5f04fa07   Ilyes Choubani   general update
427
428
                cgwindow,'dustemcgwin_dataset', st, dustem_used,U_spec,SED_spec, dataset='USED', /refresh, nodata=0, /norm,position=np_used, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
                
18e4331f   Ilyes Choubani   general update (f...
429
430
431
432
433
            endif else begin
            ;stop
                ;Plotting of postive values if they exist (if hidden data is present it is plotted if not an empty plot is rendred)
                cgwindow,'dustemcgwin_dataset', st, dataset='USED', position=p_used, /addcmd, winid=winid_m,/positive_only, _extra=_extra & cmdind_m+=1
                ;Refreshing the positive_only plot ONLY if there is data. If not do nothing
5f04fa07   Ilyes Choubani   general update
434
                cgwindow,'dustemcgwin_dataset', st, dustem_used,U_spec,SED_spec, dataset='USED',/positive_only, /refresh ,position=p_used, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
435
436
437
                
                cgwindow,'dustemcgwin_dataset', st, dataset='USED', position=p_used, /addcmd, winid=winid_m,/negative_only, _extra=_extra & cmdind_m+=1
                ;Refreshing the negative_only plot ONLY if there is data. If not do nothing
5f04fa07   Ilyes Choubani   general update
438
                cgwindow,'dustemcgwin_dataset', st, dustem_used,U_spec,SED_spec, dataset='USED',/negative_only, /refresh ,position=p_used, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
439
440
441
442
                
                !dustemcgwin_ncmds.used.pl = cmdind_m
                
                cgwindow,'dustemcgwin_dataset', st, dataset='USED',/norm, position=np_used, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1 ;I think nodata can also be uused too
5f04fa07   Ilyes Choubani   general update
443
                cgwindow,'dustemcgwin_dataset', st, dustem_used,U_spec,SED_spec, dataset='USED', /norm, /refresh,position=np_used, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
444
                !dustemcgwin_ncmds.used.nrm = cmdind_m
5f04fa07   Ilyes Choubani   general update
445
                
18e4331f   Ilyes Choubani   general update (f...
446
447
448
449
450
451
        endelse       
      endelse
      
      if ~test_psi_em then begin ; psi_em data is not present (For completeness) # This is only valid when !run_pol=1
          
          cgwindow,'dustemcgwin_dataset', st, dataset='psi_em', /nodata, position=p_psised, /addcmd, winid=winid_m, _extra=_extra  & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
452
453
454
455
456

      endif else begin ;psi_em exists

         if  ~iswinsed then begin
             cmdind_m = !dustemcgwin_ncmds.psi_em.pl
5f04fa07   Ilyes Choubani   general update
457
             cgwindow,'dustemcgwin_dataset', st, dustem_psi_em,PSI_spec,SED_spec, dataset='psi_em', /refresh ,position=p_psised, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
af5bca1f   Ilyes Choubani   general update
458
             
18e4331f   Ilyes Choubani   general update (f...
459
460
461
         endif else begin
         ;stop
             cgwindow,'dustemcgwin_dataset', st, dataset='psi_em', position=p_psised, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
462
             cgwindow,'dustemcgwin_dataset', st, dustem_psi_em,PSI_spec,SED_spec, dataset='psi_em', /refresh ,position=p_psised, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
463
             !dustemcgwin_ncmds.psi_em.pl = cmdind_m
af5bca1f   Ilyes Choubani   general update
464

18e4331f   Ilyes Choubani   general update (f...
465
466
         endelse       
      endelse
c8368c6e   Ilyes Choubani   updating plotting...
467
        
18e4331f   Ilyes Choubani   general update (f...
468
469
470
471
      
      if ~test_polsed then begin ; polsed data is not present (For completeness) # This is only valid when !run_pol=1
          
          cgwindow,'dustemcgwin_dataset', st, dataset='polsed', /nodata, position=p_psed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
472
          cgwindow,'dustemcgwin_dataset', st, dataset='polsed', /nodata, /norm, position=np_psed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
473
474
475
476
477

      endif else begin ;polsed exists

         if  ~iswinsed then begin
             cmdind_m = !dustemcgwin_ncmds.polsed.pl
5f04fa07   Ilyes Choubani   general update
478
             cgwindow,'dustemcgwin_dataset', st, dustem_polsed,P_spec, dataset='polsed', /refresh ,position=p_psed, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
18e4331f   Ilyes Choubani   general update (f...
479
             cmdind_m = !dustemcgwin_ncmds.polsed.nrm
5f04fa07   Ilyes Choubani   general update
480
             cgwindow,'dustemcgwin_dataset', st, dustem_polsed,P_spec, dataset='polsed', /norm, /refresh,position=np_psed, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
18e4331f   Ilyes Choubani   general update (f...
481
482
483
         endif else begin
         ;stop
             cgwindow,'dustemcgwin_dataset', st, dataset='polsed', position=p_psed, /addcmd, winid=winid_m, _extra=_extra  & cmdind_m+=1  
5f04fa07   Ilyes Choubani   general update
484
             cgwindow,'dustemcgwin_dataset', st, dustem_polsed,P_spec, dataset='polsed', /refresh ,position=p_psed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
485
486
             !dustemcgwin_ncmds.polsed.pl = cmdind_m
             cgwindow,'dustemcgwin_dataset', st, dataset='polsed',/norm, position=np_psed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1 ;I think nodata can also be upolsed too
5f04fa07   Ilyes Choubani   general update
487
             cgwindow,'dustemcgwin_dataset', st, dustem_polsed,P_spec, dataset='polsed', /norm, /refresh,position=np_psed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
488
489
490
             !dustemcgwin_ncmds.polsed.nrm = cmdind_m
         endelse       
      endelse      
af5bca1f   Ilyes Choubani   general update
491
492
      
      
af5bca1f   Ilyes Choubani   general update
493
494
495
      if ~test_polfrac then begin ; polfrac data is not present (For completeness) # This is only valid when !run_pol=1
          
          cgwindow,'dustemcgwin_dataset', st, dataset='polfrac', /nodata, position=p_spsed, /addcmd, winid=winid_m, _extra=_extra  & cmdind_m+=1
18e4331f   Ilyes Choubani   general update (f...
496

af5bca1f   Ilyes Choubani   general update
497
      endif else begin ;polfrac exists
18e4331f   Ilyes Choubani   general update (f...
498

af5bca1f   Ilyes Choubani   general update
499
500
         if  ~iswinsed then begin
             cmdind_m = !dustemcgwin_ncmds.polfrac.pl
5f04fa07   Ilyes Choubani   general update
501
             cgwindow,'dustemcgwin_dataset', st, dustem_polfrac,SP_spec,SED_spec, dataset='polfrac', /refresh ,position=p_spsed, winid=winid_m,/replacecmd,cmdindex=cmdind_m, _extra=_extra
af5bca1f   Ilyes Choubani   general update
502
503
504
505
             
         endif else begin
         ;stop
             cgwindow,'dustemcgwin_dataset', st, dataset='polfrac', position=p_spsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
5f04fa07   Ilyes Choubani   general update
506
             cgwindow,'dustemcgwin_dataset', st, dustem_polfrac,SP_spec,SED_spec, dataset='polfrac', /refresh ,position=p_spsed, /addcmd, winid=winid_m, _extra=_extra & cmdind_m+=1
af5bca1f   Ilyes Choubani   general update
507
             !dustemcgwin_ncmds.polfrac.pl = cmdind_m
18e4331f   Ilyes Choubani   general update (f...
508

af5bca1f   Ilyes Choubani   general update
509
510
         endelse       
      endelse  
5f04fa07   Ilyes Choubani   general update
511
      
18e4331f   Ilyes Choubani   general update (f...
512

5f04fa07   Ilyes Choubani   general update
513
514
    ENDIF
        
c8368c6e   Ilyes Choubani   updating plotting...
515
    end_m:
2910e8ce   Ilyes Choubani   Draft version of ...
516
    
2910e8ce   Ilyes Choubani   Draft version of ...
517
518
519
520
521
522
523
524
525
526
527
    ;cgcontrol, update=1
;     varrr=cgquery(dimensions=dim_m) ;be careful because the dim_m array can be multi-dimensional because of the presence of two windows.
;     cgcontrol, update=1
;     cgcontrol, resize=[dim_m(0),dim_m(1)]
;     
    ;cgcontrol, resize=1
;     cgcontrol,update=1
;     cgcontrol,update=1
        
;     cgcontrol, resize=[!D.X_SIZE,!D.Y_SIZE]
    
2910e8ce   Ilyes Choubani   Draft version of ...
528
    ;cgcontrol, update=1
5f04fa07   Ilyes Choubani   general update
529
530
531
532
533
534
535
536
    ;cgcontrol, update=0
    
    
 ;   cgcontrol, update=1 
    
    
    
    
2910e8ce   Ilyes Choubani   Draft version of ...
537
    ;varr=cgquery(dimensions=dim_m,objectref=winobj_m)
18e4331f   Ilyes Choubani   general update (f...
538
   ;stop
5f04fa07   Ilyes Choubani   general update
539
540
    cgcontrol, winid_m, execute=1
    ;cgcontrol, winid_m, execute=0      
2910e8ce   Ilyes Choubani   Draft version of ...
541
         
5f04fa07   Ilyes Choubani   general update
542
543
544
545
546
547
548
ENDIF 


;Plotting of the parameter and plugin values / This will have to be placed after the extinction block which hasn't been 
;written yet. 

;This block will be different because it does not depend on wether dustemwrap is used in polarization or not
af5bca1f   Ilyes Choubani   general update
549
550


2910e8ce   Ilyes Choubani   Draft version of ...
551
;stop
5f04fa07   Ilyes Choubani   general update
552
553
;Plotting the parameter window 
;cgcontrol, execute=0
40597848   Ilyes Choubani   Plotting of numbe...
554
555


5f04fa07   Ilyes Choubani   general update
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
IF ~iswinprms THEN BEGIN;(NEXT RUNS)
    
    winid_prms = !dustemcgwin_id.prms
    cgcontrol, winid_prms, execute=0
    cgset, winid_prms
    cmdind_prms = !dustemcgwin_ncmds.prms.pl
    cgwindow,'dustemcgwin_dataset', st, res, errors, p_dim,dataset='PARAMETERS', /refresh, winid=winid_prms,/replacecmd,cmdindex=cmdind_prms, _extra=_extra
    cgcontrol, winid_prms ,execute=1 
ENDIF ELSE BEGIN ;(FIRST RUN)
    cgwindow,wxsize=350,wysize=200,wtitle='DUSTEMWRAP v2.0 (PARAMETERS)' ; keeping the same y dimension of the emission/extinction plot? 
    winid_prms = cgquery(dimensions=dim_prms,/current) ;we don't need the dimension of the window so far/ I don't know why I needed it before
    cgcontrol, winid_prms, execute=0
    !dustemcgwin_id.prms = winid_prms
    cgwindow,'dustemcgwin_dataset', st, res, errors, p_dim,dataset='PARAMETERS', /addcmd , winid=winid_prms,_extra=_extra ;& cmdind_prms+=1
    cgwindow,'dustemcgwin_dataset', st, res, errors, p_dim,dataset='PARAMETERS', /addcmd, /refresh , winid=winid_prms, _extra=_extra & cmdind_prms+=1
    !dustemcgwin_ncmds.prms.pl = cmdind_prms
    cgcontrol, winid_prms ,execute=1        
ENDELSE 

IF ~iswinplgns THEN BEGIN;(NEXT RUNS)
    
    winid_plgns = !dustemcgwin_id.plgns
    cgcontrol, winid_plgns, execute=0
    cgset, winid_plgns
    cmdind_plgns = !dustemcgwin_ncmds.plgns.pl
    cgwindow,'dustemcgwin_dataset', st, res, errors, p_dim,dataset='PLUGINS', /refresh, winid=winid_plgns,/replacecmd,cmdindex=cmdind_plgns, _extra=_extra
    cgcontrol, winid_plgns ,execute=1 
ENDIF ELSE BEGIN ;(FIRST RUN)
    cgwindow,wxsize=350,wysize=200,wtitle='DUSTEMWRAP v2.0 (PLUGINS)' ; keeping the same y dimension of the emission/extinction plot? 
    winid_plgns = cgquery(dimensions=dim_plgns,/current) ;we don't need the dimension of the window so far/ I don't know why I needed it before
    cgcontrol, winid_plgns, execute=0
    !dustemcgwin_id.plgns = winid_plgns
    cgwindow,'dustemcgwin_dataset', st, res, errors, p_dim,dataset='PLUGINS', /addcmd , winid=winid_plgns,_extra=_extra ;& cmdind_prms+=1
    cgwindow,'dustemcgwin_dataset', st, res, errors, p_dim,dataset='PLUGINS', /addcmd, /refresh , winid=winid_plgns, _extra=_extra & cmdind_plgns+=1
    !dustemcgwin_ncmds.plgns.pl = cmdind_plgns
    cgcontrol, winid_plgns ,execute=1        
ENDELSE 
2910e8ce   Ilyes Choubani   Draft version of ...
593
594


2910e8ce   Ilyes Choubani   Draft version of ...
595
END