exponenta event banner

дифференцироваться

Дифференцироваться cfit или sfit объект

Описание

Примечание

Используйте эти синтаксисы для cfit объекты.

fx = differentiate(FO, X) дифференцирует cfit объект FO в точках, указанных вектором X и возвращает результат в fx.

пример

[fx, fxx] = differentiate(FO, X) дифференцирует cfit объект FO в точках, указанных вектором X и возвращает результат в fx и вторая производная в fxx.

Примечание

Используйте эти синтаксисы для sfit объекты.

[fx, fy] = differentiate(FO, X, Y) дифференцирует поверхность FO в точках, указанных X и Y и возвращает результат в fx и fy.

FO является посадкой поверхности (sfit) объект, сгенерированный fit функция.

X и Y массивы с двойной точностью должны иметь одинаковый размер и форму.

Все возвращаемые аргументы имеют тот же размер и форму, что и X и Y.

Если FO представляет поверхность z = f (x, y), затемFX содержит производные по отношению к x, то есть dfdx, и FY содержит производные по отношению к y, то есть dfdy.

[fx, fy] = differentiate(FO, [X, Y]), где X и Y являются векторами столбцов, позволяют указать точки вычисления в качестве одного аргумента.

[fx, fy, fxx, fxy, fyy] = differentiate(FO, ...) вычисляет первую и вторую производные объекта посадки поверхности FO.

fxx содержит вторые производные по отношению к x, то есть, ∂2f∂x2.

fxy содержит смешанные вторые производные, то есть ∂2f∂x∂y.

fyy содержит вторые производные по отношению к y, то есть, ∂2f∂y2.

Примеры

свернуть все

Создайте синусоидальный сигнал базовой линии.

xdata = (0:.1:2*pi)';
y0 = sin(xdata);

Добавьте в сигнал зависимый от отклика гауссов шум.

noise = 2*y0.*randn(size(y0)); 											
ydata = y0 + noise;

Поместите шумные данные с помощью пользовательской синусоидальной модели.

f = fittype('a*sin(b*x)');
fit1 = fit(xdata,ydata,f,'StartPoint',[1 1]);

Найдите производные подгонки в предикторах.

[d1,d2] = differentiate(fit1,xdata);

Постройте график данных, аппроксимации и производных.

subplot(3,1,1)
plot(fit1,xdata,ydata) % cfit plot method
subplot(3,1,2)
plot(xdata,d1,'m') % double plot method
grid on
legend('1st derivative')
subplot(3,1,3)
plot(xdata,d2,'c') % double plot method
grid on
legend('2nd derivative')

Figure contains 3 axes. Axes 1 contains 2 objects of type line. These objects represent data, fitted curve. Axes 2 contains an object of type line. This object represents 1st derivative. Axes 3 contains an object of type line. This object represents 2nd derivative.

Можно также вычислять и выводить на печать производные непосредственно с помощью cfit plot способ следующим образом:

figure
plot(fit1,xdata,ydata,{'fit','deriv1','deriv2'})

Figure contains 3 axes. Axes 1 contains 2 objects of type line. These objects represent data, fitted curve. Axes 2 contains an object of type line. This object represents first derivative. Axes 3 contains an object of type line. This object represents second derivative.

plot однако метод не возвращает данные о производных, в отличие от differentiate способ.

Вы можете использовать differentiate чтобы вычислить градиенты посадки, а затем использовать quiver функция для построения этих градиентов в виде стрелок. В этом примере градиенты отображаются поверх контурного графика.

Создайте точки деривации и подгоните данные.

x = [0.64;0.95;0.21;0.71;0.24;0.12;0.61;0.45;0.46;...
0.66;0.77;0.35;0.66];
y = [0.42;0.84;0.83;0.26;0.61;0.58;0.54;0.87;0.26;...
0.32;0.12;0.94;0.65];
z = [0.49;0.051;0.27;0.59;0.35;0.41;0.3;0.084;0.6;...
0.58;0.37;0.19;0.19];
fo = fit( [x, y], z, 'poly32', 'normalize', 'on' );
[xx, yy] = meshgrid( 0:0.04:1, 0:0.05:1 );

Вычислите градиенты посадки с помощью differentiate функция.

[fx, fy] = differentiate( fo, xx, yy );

Используйте quiver для построения графика градиентов.

plot( fo, 'Style', 'Contour' );
hold on
h = quiver( xx, yy, fx, fy, 'r', 'LineWidth', 2 );
hold off
colormap( copper )

Figure contains an axes. The axes contains 2 objects of type contour, quiver.

При необходимости использования дериватов в оптимизации можно, например, реализовать целевую функцию для fmincon следующим образом.

function [z, g, H] = objectiveWithHessian( xy )

% The input xy represents a single evaluation point

z = f( xy );

if nargout > 1

[fx, fy, fxx, fxy, fyy] = differentiate( f, xy );

g = [fx, fy];

H = [fxx, fxy; fxy, fyy];

end

end

Входные аргументы

свернуть все

Функция для дифференциации, указанная как cfit объект для кривых или как sfit объект для поверхностей.

Точки, в которых дифференцируется функция, заданная как вектор. Для поверхностей этот аргумент должен иметь одинаковый размер и форму Y.

Точки, в которых дифференцируется функция, заданная как вектор. Для поверхностей этот аргумент должен иметь одинаковый размер и форму X.

Выходные аргументы

свернуть все

Первая производная функции, возвращаемая как вектор того же размера и формы X и Y.

Если FO является поверхностью, z = f (x, y), то fx содержит производные по отношению кx.

Вторая производная функции, возвращаемая как вектор того же размера и формы X и Y.

Если FO является поверхностью, z = f (x, y), то fxx содержит вторые производные относительноx.

Первая производная функции, возвращаемая как вектор того же размера и формы X и Y.

Если FO является поверхностью, z = f (x, y), то fy содержит производные по отношению кy.

Вторая производная функции, возвращаемая как вектор того же размера и формы X и Y.

Если FO является поверхностью, z = f (x, y), то fyy содержит вторые производные относительноy.

Смешанная вторая производная функции, возвращаемая как вектор того же размера и формы X и Y.

Совет

Для библиотечных моделей с закрытыми формами на панели инструментов выполняется аналитический расчет производных. Для всех остальных моделей панель инструментов вычисляет первую производную с использованием коэффициента центрированной разности.

dfdx = f (x + Δx) f (x − Δx) 2Δx

где x - значение, при котором панель инструментов вычисляет производную, Δx - небольшое число (в порядке корня куба eps), f (x + Δx) равноfun оценивается при x + Δx, и f (x − xΔ) равноfun оценивается при x Δx.

Панель инструментов вычисляет вторую производную с помощью выражения

d2fdx2 = f (x + Δx) + f (x Δx) − 2f (x) (Δx) 2

Панель инструментов вычисляет смешанную производную для поверхностей с помощью выражения

∂2f∂x∂y (x, y) = f (x + Δx, y + Δy) f (x Δx, y + Δy) f (x + Δx, y − Δy) + f (x − Δx, y − Δy) 4ΔxΔy

Представлен до R2006a