Я выполняю некоторую обработку сигнала, и у меня есть al oop в Python, в котором я пытаюсь оптимизировать результат, ln (B), по параметру alpha. Когда я запустил его, я получил оптимальное значение альфа -0,8, но когда я использовал его в своем обычном коде, он дал мне результат, отличный от того, что дал мне l oop. Для ясности, результат обычного кода был ~ 4, а результат l oop для альфа = -0.8 был ~ 5.
Я подумал, что это странно, поэтому после двойной проверки на идентичность процесса в каждом случае я запустил код l oop для одного экземпляра alpha = -0,8 и получил тот же результат, что и обычный код, 4, в отличие от результата l oop дал мне при альфа = -0,8 при итерации по диапазону. Затем я перебрал код по списку [-0.8,-0.8,-0.8, -0.8, -0.8, -0.8]
и обнаружил, что для первого -0,8 я получил 4, а затем для каждого последующего получил 5.
Есть ли какая-то причина, по которой al oop будет дайте мне другой ответ или процесс для первого пункта, чем остальные? Я смотрел на это часами и не могу найти свою ошибку. Я подумал, может быть, я не сбрасывал переменную, но разница возникает только между первой и остальной итерацией, а не для каждой итерации.
Это мой l oop:
alpharange = [-0.8,-0.8,-0.8, -0.8, -0.8, -0.8]
for alpha in alpharange:
run += 1
print("Run {0}, alpha = {1}".format(run, alpha))
#find var_n
denominator = 0
r = np.arange(1,16)
for n in r:
if n*fecho <= fmax:
denominator += (n*fecho)**(2-2*alpha)/(var_f[n*nf])**2
var_n = numerator/denominator
print("var_n = ", var_n)
#find lnB
YB_ln = np.zeros(spec_H1.shape)
B_t = np.arange(0,len(YB_ln[0,:]),1) #length of a row
B_f = np.arange(0,len(YB_ln[:,0]),1) #length of a column
for nt in tzoomindx:
for nf in fzoomindx:
for n in r:
if n*nf<realfreqs.size-1:
f = realfreqs[n*nf]
YB_ln[nf,nt] += (np.abs(2*np.real(spec_H1[n*nf,nt]*np.conj(spec_L1[n*nf,nt])) + np.abs(spec_H1[n*nf,nt])**2 + np.abs(spec_L1[n*nf,nt])**2 ))/(1/(var_n*(1/f**alpha)) + 1/var_f[n*nf]) - np.log(1 + (var_n*(1/f**alpha))/var_f[n*nf])
peak = np.max(YB_ln)
peakcoord = np.where((YB_ln==peak))
if peak > lnB_max:
alpha_max = alpha
lnB_max = peak
time_max = t[peakcoord[1]]-tinterval
freq_max = realfreqs[peakcoord[0]]
var_n_max = var_n
print("!!!!!NEW MAX: alpha = {0} with peak {1} at time {2} and frequency {3}".format(alpha_max,lnB_max,time_max,freq_max))
alphalist.append(alpha)
lnBlist.append(peak)
timelist.append(t[peakcoord[1]]-tinterval)
freqlist.append(realfreqs[peakcoord[0]])
print("Peak lnB = {0} at time {1} and frequency {2}. Time: {3} min {4} s".format(peak,t[peakcoord[1]]-tinterval,realfreqs[peakcoord[0]],(time.time()-start_time)//60,(time.time()-start_time)%60))
print("lnB is optimized at alpha = {0} with peak {1} at time {2} and frequency {3}, var_n = {4}".format(alpha_max,lnB_max,time_max,freq_max,var_n_max))
print("Run took {0} min, {1} s".format((time.time()-start_time)//60,(time.time()-start_time)%60))
и вывод:
Run 1, alpha = -0.8
var_n = (1.1668471858083481e-14+0j)
/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:72: ComplexWarning: Casting complex values to real discards the imaginary part
!!!!!NEW MAX: alpha = -0.8 with peak 4.115523906554817 at time [1.0625] and frequency [72.]
Peak lnB = 4.115523906554817 at time [1.0625] and frequency [72.]. Time: 0.0 min 0.3648514747619629 s
Run 2, alpha = -0.8
var_n = (3.664163403845884e-14+0j)
!!!!!NEW MAX: alpha = -0.8 with peak 5.330720524005124 at time [1.0625] and frequency [72.]
Peak lnB = 5.330720524005124 at time [1.0625] and frequency [72.]. Time: 0.0 min 0.702958345413208 s
Run 3, alpha = -0.8
var_n = (3.664163403845884e-14+0j)
Peak lnB = 5.330720524005124 at time [1.0625] and frequency [72.]. Time: 0.0 min 1.0434083938598633 s
Run 4, alpha = -0.8
var_n = (3.664163403845884e-14+0j)
Peak lnB = 5.330720524005124 at time [1.0625] and frequency [72.]. Time: 0.0 min 1.375929832458496 s
Run 5, alpha = -0.8
var_n = (3.664163403845884e-14+0j)
Peak lnB = 5.330720524005124 at time [1.0625] and frequency [72.]. Time: 0.0 min 1.7248213291168213 s
Run 6, alpha = -0.8
var_n = (3.664163403845884e-14+0j)
Peak lnB = 5.330720524005124 at time [1.0625] and frequency [72.]. Time: 0.0 min 2.0683481693267822 s
lnB is optimized at alpha = -0.8 with peak 5.330720524005124 at time [1.0625] and frequency [72.], var_n = (3.664163403845884e-14+0j)
Run took 0.0 min, 2.069751739501953 s
(я игнорирую эту ошибку, потому что комплексные значения имеют только действительную часть).
Мне ясно, что меняется переменная var_n, и это что срывает мой результат. Я просто не уверен, почему отличается только для первой итерации.
Мой полный код со всеми определениями переменных выглядит следующим образом, я просто не хотел загромождать приведенный выше :
start_time = time.time()
#find the energy over the leading seconds
dt = t[1] - t[0]
inspiral = np.where((t-tinterval >= -2) & (t-tinterval <= 0))
Einspiral_sum = np.sum(E[inspiral])*dt
print("Summed E_inspiral = ", Einspiral_sum)
#find the 'constant'
noise = np.where((t-tinterval <= -5) & (t-tinterval >= -50))
Enoise = np.sum(E[noise])/(E[noise].size)
print("E_noise = ", Enoise)
#finding the variance
var_f = var_f_same
fecho = 72
nf = np.where((realfreqs==fecho))
nf = int(nf[0])
fmax = 300
tzoomindx = np.where((t-tinterval>=0.5)&(t-tinterval<=1.5))
tzoomindx = np.array(tzoomindx[0])
fzoomindx = np.where((realfreqs>=63)&(realfreqs<=92))
fzoomindx=np.array(fzoomindx[0])
upperbound = 0
lowerbound = -2
numerator = (Einspiral_sum - (Enoise*upperbound-Enoise*lowerbound))
run = 0
lnB_max = -1e5
lnBlist = []
alphalist = []
timelist = []
freqlist = []
#alpharange = np.arange(-1.5,1,0.1)
#alpharange = np.array([-0.5,-0.4,-0.3,-0.2,-0.1,0,0.1,0.2,0.3,0.4])
alpharange = [-0.8,-0.8,-0.8, -0.8, -0.8, -0.8]
for alpha in alpharange:
run += 1
print("Run {0}, alpha = {1}".format(run, alpha))
#find var_n
denominator = 0
r = np.arange(1,16)
for n in r:
if n*fecho <= fmax:
denominator += (n*fecho)**(2-2*alpha)/(var_f[n*nf])**2
var_n = numerator/denominator #for Einspiral = sum
#find lnB
YB_ln = np.zeros(spec_H1.shape)
B_t = np.arange(0,len(YB_ln[0,:]),1) #length of a row
B_f = np.arange(0,len(YB_ln[:,0]),1) #length of a column
for nt in tzoomindx:
for nf in fzoomindx:
for n in r:
if n*nf<realfreqs.size-1:
f = realfreqs[n*nf]
YB_ln[nf,nt] += (np.abs(2*np.real(spec_H1[n*nf,nt]*np.conj(spec_L1[n*nf,nt])) + np.abs(spec_H1[n*nf,nt])**2 + np.abs(spec_L1[n*nf,nt])**2 ))/(1/(var_n*(1/f**alpha)) + 1/var_f[n*nf]) - np.log(1 + (var_n*(1/f**alpha))/var_f[n*nf])
peak = np.max(YB_ln)
peakcoord = np.where((YB_ln==peak))
if peak > lnB_max:
alpha_max = alpha
lnB_max = peak
time_max = t[peakcoord[1]]-tinterval
freq_max = realfreqs[peakcoord[0]]
var_n_max = var_n
print("!!!!!NEW MAX: alpha = {0} with peak {1} at time {2} and frequency {3}".format(alpha_max,lnB_max,time_max,freq_max))
alphalist.append(alpha)
lnBlist.append(peak)
timelist.append(t[peakcoord[1]]-tinterval)
freqlist.append(realfreqs[peakcoord[0]])
print("Peak lnB = {0} at time {1} and frequency {2}. Time: {3} min {4} s".format(peak,t[peakcoord[1]]-tinterval,realfreqs[peakcoord[0]],(time.time()-start_time)//60,(time.time()-start_time)%60))
print("lnB is optimized at alpha = {0} with peak {1} at time {2} and frequency {3}, var_n = {4}".format(alpha_max,lnB_max,time_max,freq_max,var_n_max))
print("Run took {0} min, {1} s".format((time.time()-start_time)//60,(time.time()-start_time)%60))
E - энергия моего сигнала, spec_H1 / spec_L1 - спектрограммы моего сигнала, и в целом я пытаюсь найти байесовский фактор сигнала в определенном временном и частотном диапазоне ,