Nếu bạn cần các công cụ phái sinh bậc cao hơn, bạn sẽ không nhận được kết quả tốt khi sử dụng các điểm dữ liệu tương đương. Nếu bạn có thể lấy mẫu hàm của mình tại các nút tùy ý, tôi khuyên bạn nên sử dụng các điểm , tức là cho đa thức độ .n
xk= cos( πkn) ,k = 0 ... n
n
Bạn có thể đánh giá đa thức ổn định bằng Nội suy Barycentric . Lưu ý rằng vì bạn đang sử dụng đa thức mức độ cao trong toàn bộ khoảng thời gian, nên có thể bạn sẽ cần ít điểm dữ liệu hơn. Cũng lưu ý rằng điều này giả định rằng dữ liệu của bạn có thể được biểu diễn bằng đa thức, tức là nó liên tục và trơn tru.
Nhận các dẫn xuất bậc cao từ nội suy là một chút khó khăn và không có điều kiện cho các dẫn xuất cao. Nó có thể được thực hiện, tuy nhiên, bằng cách sử dụng đa thức Ch Quashev . Trong Matlab / Octave (xin lỗi, Python của tôi không tốt chút nào), tuy nhiên, bạn có thể làm như sau:
% We will use the sine function as a test case
f = @(x) sin( 4*pi*x );
% Set the number of points and the interval
N = 40;
a = 0; b = 1;
% Create a Vandermonde-like matrix for the interpolation using the
% three-term recurrence relation for the Chebyshev polynomials.
x = cos( pi*[0:N-1]/(N-1) )';
V = ones( N ); V(:,2) = x;
for k=3:N, V(:,k) = 2*x.*V(:,k-1) - V(:,k-2); end;
% Compute the Chebyshev coefficients of the interpolation. Note that we
% map the points x to the interval [a,b]. Note also that the matrix inverse
% can be either computed explicitly or evaluated using a discrete cosine transform.
c = V \ f( (a+b)/2 + (b-a)/2*x );
% Compute the derivative: this is a bit trickier and relies on the relationship
% between Chebyshev polynomials of the first and second kind.
temp = [ 0 ; 0 ; 2*(N-1:-1:1)'.*c(end:-1:2) ];
cdiff = zeros( N+1 , 1 );
cdiff(1:2:end) = cumsum( temp(1:2:end) );
cdiff(2:2:end) = cumsum( temp(2:2:end) );
cdiff(end) = 0.5*cdiff(end);
cdiff = cdiff(end:-1:3);
% Evaluate the derivative fp at the nodes x. This is useful if you want
% to use Barycentric Interpolation to evaluate it anywhere in the interval.
fp = V(:,1:n-1) * cdiff;
% Evaluate the polynomial and its derivative at a set of points and plot them.
xx = linspace(-1,1,200)';
Vxx = ones( length(xx) , N ); Vxx(:,2) = xx;
for k=3:N, Vxx(:,k) = 2*xx.*Vxx(:,k-1) - Vxx(:,k-2); end;
plot( (a+b)/2 + (b-a)/2*xx , [ Vxx*c , Vxx(:,1:N-1)*cdiff ] );
Mã để tính đạo hàm có thể được áp dụng lại nhiều lần để tính đạo hàm cao hơn.
Nếu bạn sử dụng Matlab, bạn có thể quan tâm đến dự án Chebfun , phần lớn thực hiện điều này một cách tự động và từ đó các phần của ví dụ mã ở trên đã được thực hiện. Chebfun có thể tạo ra một phép nội suy từ bất kỳ hàm nào theo nghĩa đen, ví dụ như liên tục, không liên tục, với các điểm kỳ dị, v.v ... và sau đó tính tích phân, đạo hàm của nó, sử dụng nó để giải ODE, v.v ...
k=4
trong cuộc gọi đếnscipy.interpolate.UnivariateSpline
, thì spline là quartic.