-
Notifications
You must be signed in to change notification settings - Fork 1
/
example_brem_sgpl.pro
56 lines (47 loc) · 2.65 KB
/
example_brem_sgpl.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
Pro example_brem_sgpl, photon_spec
; Example script to use brem_nontherm.pro for bremsstrahlung calculation:
; calculate x-ray spectrum from a single-power-law electron distribution and compare with
; the results calculated by brm2_thintarget.
;
; Outputs:
; photon_spec: structure containing photon energy array (in keV) and the corresponding
; photon fluxes (photons s^-1 keV^-1 cm^-2)
;
; Calling Sequence:
; example_brem_sgpl, photon_spec
;
eph = findgen(101) ; Photon energies (keV)
emin = 0.1 ; Min electron energy (keV)
emax = 1.e4 ; Max electron energy
bin= 0.001 ; Electron energy bin (in log space)
nbin = fix((alog(emax)-alog(emin))/bin)
eel = findgen(nbin+1)*bin + alog(emin)
eel = get_edges( exp(eel), /mean ) ;Electron energies (keV)
delta = 3. ; Electron spectral index
n_e = 1.e5*eel^(-delta) ; Electron density distribution that follows a single power law (cm^-3/keV)
n_0 = 1.e10 ; Ambient density (cm^-3)
vol = (1.d8)^3 ; volume of source (cm^3)
gamma = eel/510.98d00+1 ; relativistic gamma (kinetic E / rest E + 1)
c = 3e10 ; speed of light in cm/s
v = c*sqrt(1-1./gamma^2) ; relativistic velocity
; Photon spectrum (photons s^-1 keV^-1 cm^-2)
flux = brem_nontherm( eel, n_e, eph, n_0, vol )
; Here's the RHESSI power-law thin-target calculation for comparison:
el_f_tot = tsum( eel, n_e*v ) ; Total flux density of nonthermal electrons
; (n_e*v integrated over energy, cm^-2 s^-1)
a0 = n_0*el_f_tot*vol ; Normalization factor
flux_compare = a0*brm2_thintarget( eph, [1.,delta-0.5,1.e5,delta-0.5,0.1,1e4] )
; Brm2_ThinTarget uses electron FLUX density distribution, so the spectral indices
; to be put in here is different from the spectral indices for the electron density
; distribution. The relation is delta_f=delta-0.5 for sub-relativistic cases.
loadct, 0
hsi_linecolors
plot, eph, flux, /xlo, /ylo, xra=[1.,100.], thick=2, color=0, background=1,charsize=1.5, $
xtitle='Photon energy [keV]', ytitle='X-ray flux [phot s!U-1!N keV!U-1!N cm!U-2!N', $
title = 'Bremsstrahlung X-ray spectrum (single power law)'
oplot, eph, flux_compare, color=6, thick=2
al_legend, ['brem_nontherm','brm2_thintarget'], lines=0, thick=2, col=[0,6], box=0, $
charsize=1.5, linsi=0.3, /right
photon_spec = create_struct("energy_keV", eph, "photon_flux", flux)
;stop
End