Теперь мой код на Python предназначен для интеграции выражения с \(W_{1:3}\), равным \(1,2,3\) соответственно , \(r_1 = 0\), \(v\), то есть дисперсия равна \(1\), а постоянная времени \(tau\) равна \(1\), я хотите оценить корни производной, чтобы найти \(D\) следующим образом:
import sympy as sp
import math
w_n = [0,1,2]
r_1 = sp.Symbol("r_1")
r_2 = sp.Symbol("r_2")
r_3 = sp.Symbol("r_3")
r_n = [0, r_2,r_3]
D = sp.Symbol("D")
v = sp.Symbol("v")
t = sp.Symbol("t")
def expo_power(i=0,t=t,D=D,v=v):
return ((((w_n[i] - r_n[i]) ** 2)/(2 * v)) + (((r_n[i] - r_n[i-1]) ** 2)/(4 * D * t)))
def expo_power_sum(lower_bound = 2, upper_bound=3,t=t,D=D,v=v):
f = 0
for i in range(lower_bound,upper_bound):
f += expo_power(i-1,t=t,D=D,v=v)
return f
def P_w_n_P_r_n(i=0,v=v,D=D,t=t):
return (1/(8 * (sp.pi ** 2) * D * t * v)) \
* sp.exp(-expo_power_sum(lower_bound=2,upper_bound=3,t=t,D=D,v=v))
def P_w_i_r_i(i = 0, v=v):
return (1/(sp.sqrt(2 * sp.pi * v))) \
* sp.exp(-((w_n[i] - r_n[i]) ** 2/(2 * v)))
def normal_dist(x =0, m = r_n[0], v =v):
return (1/(sp.sqrt(2 * sp.pi * v))) \
* sp.exp(-(((x - m) ** 2)/(2 * v)))
def integrand(v = v,t=t,lower = 2):
f = P_w_n_P_r_n(i=lower,v=v,D=D,t=t)
sp.pprint(f)
f = f * P_w_i_r_i(v=v)
f = f * normal_dist(x=r_n[0],v=v)
return f
def integrate(v=v,t=t, lower_bound = -sp.oo, upper_bound= sp.oo):
function = integrand(v=v,t=t)
integral_1 = sp.integrate(function, (r_1, lower_bound, upper_bound)).evalf()
sp.pprint(integral_1)
integral_2 = sp.integrate(integral_1, (r_3, lower_bound, upper_bound)).evalf()
sp.pprint(integral_2)
integral_3 = sp.integrate(integral_2, (r_2, lower_bound, upper_bound)).evalf()
num = sp.N(integral_3)
print(num)
#sp.pprint(integral_3)
deriv = sp.diff(num, D)
sol = sp.solve(deriv, D)
sp.pprint(sol)
integrate(v=1,t=1,lower_bound=-1000,upper_bound=1000)
Теперь отображаемое решение представляет собой отношение двух невычисленных интегралов.
обратите внимание, что
и t в коде Python равен (tau), и мы находим корни производной относительно до (D) после маргинализации (r_1,r_2,r_3) интеграл не вычисляется, в частности для (r_2)
Имеет ли интеграл замкнутый вид? если да, то можно ли решить производную формы для $D$? если нет, то какова альтернатива для получения решения для $P'(w_{1:3}|D,v) = 0$ относительно $D$?
Где переменные имеют следующее распределение: [img]https://i.sstatic.net/9QZiS5dK.png[/img]
Таким образом, интеграл принимает вид:
[img]https://i.sstatic.net/MBH3lwep.png[/img]
Теперь мой код на Python предназначен для интеграции выражения с \(W_{1:3}\), равным \(1,2,3\) соответственно , \(r_1 = 0\), \(v\), то есть дисперсия равна \(1\), а постоянная времени \(tau\) равна \(1\), я хотите оценить корни производной, чтобы найти \(D\) следующим образом: [code]import sympy as sp import math
w_n = [0,1,2] r_1 = sp.Symbol("r_1") r_2 = sp.Symbol("r_2") r_3 = sp.Symbol("r_3") r_n = [0, r_2,r_3] D = sp.Symbol("D") v = sp.Symbol("v") t = sp.Symbol("t")
def expo_power_sum(lower_bound = 2, upper_bound=3,t=t,D=D,v=v): f = 0 for i in range(lower_bound,upper_bound): f += expo_power(i-1,t=t,D=D,v=v) return f
def P_w_n_P_r_n(i=0,v=v,D=D,t=t): return (1/(8 * (sp.pi ** 2) * D * t * v)) \ * sp.exp(-expo_power_sum(lower_bound=2,upper_bound=3,t=t,D=D,v=v))
def normal_dist(x =0, m = r_n[0], v =v): return (1/(sp.sqrt(2 * sp.pi * v))) \ * sp.exp(-(((x - m) ** 2)/(2 * v)))
def integrand(v = v,t=t,lower = 2): f = P_w_n_P_r_n(i=lower,v=v,D=D,t=t) sp.pprint(f) f = f * P_w_i_r_i(v=v) f = f * normal_dist(x=r_n[0],v=v) return f
def integrate(v=v,t=t, lower_bound = -sp.oo, upper_bound= sp.oo): function = integrand(v=v,t=t) integral_1 = sp.integrate(function, (r_1, lower_bound, upper_bound)).evalf() sp.pprint(integral_1) integral_2 = sp.integrate(integral_1, (r_3, lower_bound, upper_bound)).evalf() sp.pprint(integral_2) integral_3 = sp.integrate(integral_2, (r_2, lower_bound, upper_bound)).evalf() num = sp.N(integral_3) print(num) #sp.pprint(integral_3) deriv = sp.diff(num, D) sol = sp.solve(deriv, D) sp.pprint(sol) integrate(v=1,t=1,lower_bound=-1000,upper_bound=1000) [/code] Теперь отображаемое решение представляет собой отношение двух невычисленных интегралов. обратите внимание, что [img]https://i.sstatic.net/gwFU4R1I.png[/img] и t в коде Python равен (tau), и мы находим корни производной относительно до (D) после маргинализации (r_1,r_2,r_3) интеграл не вычисляется, в частности для (r_2) Имеет ли интеграл замкнутый вид? если да, то можно ли решить производную формы для $D$? если нет, то какова альтернатива для получения решения для $P'(w_{1:3}|D,v) = 0$ относительно $D$?