Blame view

src/idl/dustem_fillup_systvar_from_fits.pro 3.61 KB
b7dca888   Jean-Philippe Bernard   improved to recov...
1
2
3
4
PRO dustem_fillup_systvar_from_fits,syst_var,str_input_SED,used_pol

	Nsed=n_elements(str_input_SED)
	sed=dustem_initialize_internal_sed(Nsed)
244eeac8   Jean-Philippe Bernard   First commit
5
6
7
8

	(syst_var).sed=ptr_new(sed)

	(*syst_var.sed).instru_names=dustem_filter2instru(str_input_SED.filter)
2fb72ad4   Ilyes Choubani   applied correctio...
9
	(*syst_var.sed).filt_names=strtrim(str_input_SED.filter,2)
244eeac8   Jean-Philippe Bernard   First commit
10
11
12
13
14
15
	(*syst_var.sed).wav=str_input_SED.wavelength
	(*syst_var.sed).values=str_input_SED.STOKESI
	(*syst_var.sed).sigma=la_power(str_input_SED.varianceII,0.5)

	IF used_pol THEN BEGIN
		;stop
b7dca888   Jean-Philippe Bernard   improved to recov...
16
17
18
19
20
21
		;===== note: those should include only points with polarization data, not all sed points
		indq=where(str_input_SED.STOKESQ NE la_undef(),Nqsed)
        indu=where(str_input_SED.STOKESU NE la_undef(),Nused)
        qsed=dustem_initialize_internal_sed(Nqsed)
        used=dustem_initialize_internal_sed(Nused)
        indpolar=where(str_input_SED.STOKESU NE la_undef() AND str_input_SED.STOKESQ NE la_undef(),Npolar)
bd4ea161   Ilyes Choubani   completing missin...
22
        
b7dca888   Jean-Philippe Bernard   improved to recov...
23
24
25
26
27
28
29
30
31
32
33
34
35
        psi_sed=dustem_initialize_internal_sed(Npolar)
        smallp_sed=dustem_initialize_internal_sed(Npolar)
        largep_sed=dustem_initialize_internal_sed(Npolar)

		syst_var.qsed=ptr_new(qsed)
		syst_var.used=ptr_new(used)
		(*syst_var.qsed).instru_names=dustem_filter2instru(str_input_SED[indq].filter)
		(*syst_var.qsed).filt_names=strtrim(str_input_SED[indq].filter,2)
		(*syst_var.qsed).wav=str_input_SED[indq].wavelength
		(*syst_var.qsed).values=str_input_SED[indq].STOKESQ
		(*syst_var.qsed).sigma=la_power(str_input_SED[indq].varianceQQ,0.5)
		;now U
		(*syst_var.used).instru_names=dustem_filter2instru(str_input_SED[indu].filter)
bd4ea161   Ilyes Choubani   completing missin...
36
		(*syst_var.used).filt_names=strtrim(str_input_SED[indu].filter,2)
b7dca888   Jean-Philippe Bernard   improved to recov...
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
		(*syst_var.used).wav=str_input_SED[indu].wavelength
		(*syst_var.used).values=str_input_SED[indu].STOKESU
		(*syst_var.used).sigma=la_power(str_input_SED[indu].varianceUU,0.5)
		;=== add up dependent fields
        syst_var.psi_em=ptr_new(psi_sed)
        syst_var.polfrac=ptr_new(smallp_sed)
        syst_var.polsed=ptr_new(largep_sed)
		polar_iqu2ippsi,str_input_SED[indpolar].STOKESI,str_input_SED[indpolar].STOKESQ,str_input_SED[indpolar].STOKESU,p,psi,largep=largep
		(*syst_var.psi_em).values=psi
		(*syst_var.polfrac).values=p
		(*syst_var.polsed).values=largep
		CIQ=str_input_SED[indpolar].VARIANCEII & CIQ[*]=0.   ;because input SEDs don't include covariances, yet
		CIU=str_input_SED[indpolar].VARIANCEII & CIU[*]=0.   ;because input SEDs don't include covariances, yet
		CQU=str_input_SED[indpolar].VARIANCEII & CQU[*]=0.   ;because input SEDs don't include covariances, yet
		polar_variance_iqu2ippsi,str_input_SED[indpolar].STOKESI $
								,str_input_SED[indpolar].STOKESQ $
								,str_input_SED[indpolar].STOKESU $
								,str_input_SED[indpolar].VARIANCEII $
								,str_input_SED[indpolar].VARIANCEQQ $
								,str_input_SED[indpolar].VARIANCEUU $
								,CIQ,CIU,CQU,variance_smallp,variance_psi,variance_largep,/lac,snr_largeP=snr_largeP
bd4ea161   Ilyes Choubani   completing missin...
58
59
60
61
62
63
64
65
66
67
68
69
70
		
		(*syst_var.psi_em).instru_names=dustem_filter2instru(str_input_SED[indpolar].filter)
		(*syst_var.psi_em).filt_names=strtrim(str_input_SED[indpolar].filter,2)
		(*syst_var.psi_em).wav=str_input_SED[indpolar].wavelength
		
		(*syst_var.polfrac).instru_names = (*syst_var.psi_em).instru_names
		(*syst_var.polfrac).filt_names =  (*syst_var.psi_em).filt_names
		(*syst_var.polfrac).wav = (*syst_var.psi_em).wav
		
		(*syst_var.polsed).instru_names = (*syst_var.psi_em).instru_names
		(*syst_var.polsed).filt_names =  (*syst_var.psi_em).filt_names
		(*syst_var.polsed).wav = (*syst_var.psi_em).wav

b7dca888   Jean-Philippe Bernard   improved to recov...
71
72
73
		(*syst_var.psi_em).sigma=la_power(variance_psi,0.5)
        (*syst_var.polfrac).sigma=la_power(variance_smallp,0.5)
        (*syst_var.polsed).sigma=la_power(variance_largep,0.5)
244eeac8   Jean-Philippe Bernard   First commit
74
75
	ENDIF
END