Blame view

EBL-spectrums.py 3.04 KB
b5217158   Thomas Fitoussi   Python scripts to...
1
2
3
4
5
#!/bin/python

import numpy as np
from scipy.optimize import curve_fit
import matplotlib.pyplot as plt
374f3d52   Thomas Fitoussi   add Weight distri...
6
from Modules.Constants import *
b5217158   Thomas Fitoussi   Python scripts to...
7

49a0fe94   Thomas Fitoussi   Add direct printi...
8
9
fig1 = plt.figure()
ax = fig1.add_subplot(111)
b5217158   Thomas Fitoussi   Python scripts to...
10

e4ba931e   Thomas Fitoussi   Corrections:
11
z=2
b5217158   Thomas Fitoussi   Python scripts to...
12
13
14

# ==== Dominguez ====
lamb,lambdaI = np.loadtxt("EBL_files/lambdaI_Dominguez.dat",unpack=True,usecols=[0,15])
e4ba931e   Thomas Fitoussi   Corrections:
15
#lamb,lambdaI =np.loadtxt("EBL_files/lambdaI_Dominguez.dat",unpack=True,usecols=[0,1])
b5217158   Thomas Fitoussi   Python scripts to...
16
17
18
hv = h*c/(lamb*1e-4)  # erg
density = 1e-6*(4*pi/c)*lambdaI/(hv**2) /(erg_to_GeV*1e9) *(1+z)**3
hv = hv *(erg_to_GeV*1e9)
49a0fe94   Thomas Fitoussi   Add direct printi...
19
ax.plot(hv,density*hv**2,"--b",label="Dominguez et Al")
b5217158   Thomas Fitoussi   Python scripts to...
20
21
22

# ==== Kneiske and Doll - "best fit" ====
hv,density = np.loadtxt("EBL_files/n_bestfit10.dat",unpack=True,usecols=[0,1])
49a0fe94   Thomas Fitoussi   Add direct printi...
23
ax.plot(hv,density*hv**2,"--r",label="Kneiske et Doll - 'best fit'")
b5217158   Thomas Fitoussi   Python scripts to...
24
25

# ==== Kneiske and Doll - "lower limit" ====
e4ba931e   Thomas Fitoussi   Corrections:
26
27
hv,density = np.loadtxt("EBL_files/n_lowerlimit10.dat",unpack=True,usecols=[0,179])
#hv,density =np.loadtxt("EBL_files/n_lowerlimit10.dat",unpack=True,usecols=[0,1])
b5217158   Thomas Fitoussi   Python scripts to...
28
density=density*(1+z)**3
fb95bd3d   Thomas Fitoussi   Add time delay ve...
29
ax.plot(hv,density*hv**2,"--g",label="Kneiske and Doll - 'lower limit'")
b5217158   Thomas Fitoussi   Python scripts to...
30
31

# ==== Fransceschini ====
e4ba931e   Thomas Fitoussi   Corrections:
32
33
hv,density = np.loadtxt("EBL_files/n_Fra.dat",unpack=True,usecols=[0,11])
#hv,density = np.loadtxt("EBL_files/n_Fra.dat",unpack=True,usecols=[0,1])
b5217158   Thomas Fitoussi   Python scripts to...
34
density=density*(1+z)**3
fb95bd3d   Thomas Fitoussi   Add time delay ve...
35
ax.plot(hv,density*hv**2,"--c",label="Fraceschini")
b5217158   Thomas Fitoussi   Python scripts to...
36
37

# ==== Finke ====
e4ba931e   Thomas Fitoussi   Corrections:
38
39
hv,density = np.loadtxt("EBL_files/n_Finke.dat",unpack=True,usecols=[0,201])
#hv,density = np.loadtxt("EBL_files/n_Finke.dat",unpack=True,usecols=[0,1])
b5217158   Thomas Fitoussi   Python scripts to...
40
density=density*(1+z)**3
49a0fe94   Thomas Fitoussi   Add direct printi...
41
ax.plot(hv,density*hv**2,"--m",label="Finke et Al")
b5217158   Thomas Fitoussi   Python scripts to...
42
43

# ==== Gilmore ====
e4ba931e   Thomas Fitoussi   Corrections:
44
45
hv,density = np.loadtxt("EBL_files/n_Gil.dat",unpack=True,usecols=[0,14])
#hv,density = np.loadtxt("EBL_files/n_Gil.dat",unpack=True,usecols=[0,1])
49a0fe94   Thomas Fitoussi   Add direct printi...
46
ax.plot(hv,density*hv**2,"--y",label="Gilmore et Al")
b5217158   Thomas Fitoussi   Python scripts to...
47

65135318   Thomas Fitoussi   Reset modules
48
#==== CMB ====
49a0fe94   Thomas Fitoussi   Add direct printi...
49
def nCMB(E,z):
65135318   Thomas Fitoussi   Reset modules
50
51
52
53
54
55
   kTcmb = k*Tcmb*erg_to_GeV*1e9*(1+z)
   theta = E/kTcmb
   nCMB=(hb*c*erg_to_GeV*1e9)**(-3) *(E/np.pi)**2 /(np.exp(theta)-1)    
   return nCMB

hv = np.logspace(-4,-1,1000)
49a0fe94   Thomas Fitoussi   Add direct printi...
56
ax.plot(hv,nCMB(hv,z)*hv**2,"-k",label="CMB")
65135318   Thomas Fitoussi   Reset modules
57

b5217158   Thomas Fitoussi   Python scripts to...
58
59
60
ax.set_xscale('log')
ax.set_yscale('log')
ax.grid(b=True,which='major')
49a0fe94   Thomas Fitoussi   Add direct printi...
61
ax.legend(loc="best",frameon=False,framealpha=0.5)
b5217158   Thomas Fitoussi   Python scripts to...
62
ax.set_xlabel("energy [eV]")
49a0fe94   Thomas Fitoussi   Add direct printi...
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
ax.set_ylabel("$n$ [photon.eV.cm$^{-3}$]")

#==== Dominguez vs redshift ==================================================================
fig2 = plt.figure()
ax2 = fig2.add_subplot(111)

z = np.loadtxt("EBL_files/z_Dominguez.dat",unpack=True,usecols=[0])
for z_index in [1,9,12,15,17]:
   lamb,lambdaI = np.loadtxt("EBL_files/lambdaI_Dominguez.dat",unpack=True,usecols=[0,z_index])
   hv = h*c/(lamb*1e-4)  # erg
   density = 1e-6*(4*pi/c)*lambdaI/(hv**2) /(erg_to_GeV*1e9) *(1+z[z_index])**3
   hv = hv *(erg_to_GeV*1e9)
   p=ax2.plot(hv,density*hv**2,"--")
   # CMB
   hv = np.logspace(-4,-1,1000)
   ax2.plot(hv,nCMB(hv,z[z_index])*hv**2,color=p[0].get_color(),linestyle='-',label="z="+str(z[z_index-1]))

ax2.set_xscale('log')
ax2.set_yscale('log')
ax2.grid(b=True,which='major')
ax2.legend(loc="best",frameon=False,framealpha=0.5)
ax2.set_xlabel("energy [eV]")
ax2.set_ylabel("$n$ [photon.eV.cm$^{-3}$]")
b5217158   Thomas Fitoussi   Python scripts to...
86
87

plt.show()