Дигамма-функция
psi( вычисляет дигамную функцию x)x.
psi( вычисляет полигамную функцию k,x)x, который является k-я производная дигаммы функции при x.
Вычислите функции дигаммы и полигаммы для этих чисел. Поскольку эти числа не являются символическими объектами, получаются результаты с плавающей запятой.
[psi(1/2) psi(2, 1/2) psi(1.34) psi(1, sin(pi/3))]
ans = -1.9635 -16.8288 -0.1248 2.0372
Вычислите функции дигаммы и полигаммы для чисел, преобразованных в символические объекты.
[psi(sym(1/2)), psi(1, sym(1/2)), psi(sym(1/4))]
ans = [ - eulergamma - 2*log(2), pi^2/2, - eulergamma - pi/2 - 3*log(2)]
Для некоторых символических (точных) чисел, psi возвращает неразрешенные символьные вызовы.
psi(sym(sqrt(2)))
ans = psi(2^(1/2))
Вычислите производные этих выражений, содержащие функции дигаммы и полигаммы.
syms x diff(psi(1, x^3 + 1), x) diff(psi(sin(x)), x)
ans = 3*x^2*psi(2, x^3 + 1) ans = cos(x)*psi(1, sin(x))
Разверните выражения, содержащие функции digamma.
syms x expand(psi(2*x + 3)) expand(psi(x + 2)*psi(x))
ans = psi(x + 1/2)/2 + log(2) + psi(x)/2 +... 1/(2*x + 1) + 1/(2*x + 2) + 1/(2*x) ans = psi(x)/x + psi(x)^2 + psi(x)/(x + 1)
Вычислите пределы для выражений, содержащих функции дигаммы и полигаммы.
syms x limit(x*psi(x), x, 0) limit(psi(3, x), x, inf)
ans = -1 ans = 0
Вычислить дигамную функцию для элементов матрицы M и вектор V.
M = sym([0 inf; 1/3 1/2]); V = sym([1, inf]); psi(M) psi(V)
ans = [ Inf, Inf] [ - eulergamma - (3*log(3))/2 - (pi*3^(1/2))/6, - eulergamma - 2*log(2)] ans = [ -eulergamma, Inf]
Вычислить функцию полигаммы для элементов матрицы M и вектор V. psi функция действует элементарно на нескалярные входы.
M = sym([0 inf; 1/3 1/2]); polyGammaM = [1 3; 2 2]; V = sym([1, inf]); polyGammaV = [6 6]; psi(polyGammaM,M) psi(polyGammaV,V)
ans = [ Inf, 0] [ - 26*zeta(3) - (4*3^(1/2)*pi^3)/9, -14*zeta(3)] ans = [ -720*zeta(7), 0]
Потому что все элементы polyGammaV иметь то же значение, вы можете заменить polyGammaV скаляром этого значения. psi расширяет скаляр в нескаляр того же размера, что и V и вычисляет результат.
V = sym([1, inf]); psi(6,V)
ans = [ -720*zeta(7), 0]
Запрос psi для числа, которое не является символическим объектом, вызывает MATLAB ®psi функция. Эта функция принимает реальные неотрицательные аргументы x. Если требуется вычислить функцию полигаммы для комплексного числа, используйте sym чтобы преобразовать этот номер в символический объект, а затем вызовите psi для этого символического объекта.
psi(0, x) эквивалентно psi(x).