Как решить производную выражения по D?Python

Программы на Python
Ответить
Anonymous
 Как решить производную выражения по D?

Сообщение Anonymous »

Интеграл:
Изображение

Где переменные имеют следующее распределение:
Изображение

Таким образом, интеграл принимает вид:

Изображение

Теперь мой код на 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$?

Подробнее здесь: https://stackoverflow.com/questions/793 ... spect-to-d
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»