⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 csfit.m

📁 可以方便的调用这个函数
💻 M
字号:
%三次样条插值函数的Matlab实现
function S=csfit(x,y,dx0,dxn)
n=length(x)-1;
h=diff(x);
d=diff(y)./h;
a=h(2:n-1);
b=2*(h(1:n-1)+h(2:n));
c=h(2:n);
u=6*diff(d);
b(1)=b(1)-h(1)/2;
u(1)=u(1)-3*(d(1)-dx0);
b(n-1)=b(n-1)-h(n)/2;
u(n-1)=u(n-1)-3*(dxn-d(n));
for k=2:n-1
    temp=a(k-1)/b(k-1);
    b(k)=b(k)-temp*c(k-1);
    u(k)=u(k)-temp*(u(k-1));
end
m(n)=u(n-1)/b(n-1);
for k=n-2:-1:1
    m(k+1)=(u(k)-c(k)*m(k+2))/b(k);
end
m(1)=3*(d(1)-dx0)/h(1)-m(2)/2;
m(n+1)=3*(dxn-d(n))/h(n)-m(n)/2;
for k=0:n-1
    S(k+1,1)=(m(k+2)-m(k+1))/(6*h(k+1));
    S(k+1,2)=m(k+1)/2;
    S(k+1,3)=d(k+1)-h(k+1)*(2*m(k+1)+m(k+2))/6;
    S(k+1,4)=y(k+1);
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -