




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第页MATLAB三次样条插值之三弯矩法首先说这个程序并不完善,为了实现通用(1,2,…,n)格式解题,以及为调用追赶法程序,没有针对节点数在三个以下的情况进行分类讨论。希望能有朋友给出更好的方法。首先,通过函数sanwanj得到方程的系数矩阵,即追赶法方程的四个向量参数,接下来调用追赶法(在intersanwj函数中),得到三次样条分段函数系数因子,然后进行多项式合并得到分段函数的解析式,程序最后部分通过判断输入值的区间自动选择对应的分段函数并计算改点的值。附:追赶法程序chasefunction[newv,w,newu,newd]=sanwj(x,y,x0,y0,y1a,y1b)
%三弯矩样条插值
%将插值点分两次输入,x0y0单独输入
%边值条件a的二阶导数y1a和b的二阶导数y1b,这里建议将y1a和y1b换成y2a和y2b,以便于和三转角代码相区别
n=length(x);m=length(y);
ifm~=n
error('xory输入有误,再来');
end
v=ones(n-1,1);u=ones(n-1,1);d=zeros(n-1,1);
w=2*ones(n+1);
h0=x(1)-x0;
h=zeros(n-1,1);
fork=1:n-1
h(k)=x(k+1)-x(k);
end
v(1)=h0/(h0+h(1));
u(1)=1-v(1);
d(1)=6*((y(2)-y(1))/h(1)-(y(1)-y0)/h0)/(h0+h(1));
%
fork=2:n-1
v(k)=h(k-1)/(h(k-1)+h(k));
u(k)=1-v(k);
d(k)=6*((y(k+1)-y(k))/h(k)-(y(k)-y(k-1))/h(k-1))/(h(k-1)+h(k));
end
newv=[v;1];
newu=[1;u];
d0=6*((y(1)-y0)/h0-y1a)/h0;
d(n)=6*(y1b-(y(n)-y(n-1))/h(n-1))/h(n-1);
newd=[d0;d];functionintersanwj(x,y,x0,y0,y1a,y1b)
%三弯矩样条插值
%第一部分
n=length(x);m=length(y);
ifm~=n
error('xory输入有误,再来');
end
%重新定义h
h=zeros(n,1);
h(1)=x(1)-x0;
fork=2:n
h(k)=x(k)-x(k-1);
end
%sptep1调用三弯矩函数
[a,b,c,d]=sanwj(x,y,x0,y0,y1a,y1b);
%三对角方程
M=chase(a,b,c,d);
%求插值函数
fprintf('三次样条(三弯矩)插值的函数表达式\n');
symsX;
fprintf('S0--1:\n');
S(1)=collect(((1/6)*M(2)*(X-x0).^3-(1/6)*M(1)*(X-x(1)).^3+(y(1)-(M(2)*h(1).^2)/6)*(X-x0)-(y0-(M(1)*h(1).^2)/6)*(X-x(1)))/h(1));
fork=2:n
fprintf('S%d--%d:\n',k-1,k);
S(k)=collect(((1/6)*M(k+1)*(X-x(k-1)).^3-(1/6)*M(k)*(X-x(k)).^3+(y(k)-(M(k+1)*h(k).^2)/6)*(X-x(k-1))-(y(k-1)-(M(k)*h(k).^2)/6)*(X-x(k)))/h(k));
end
S=S.';
disp(S);
fprintf('以上为样条函数(三弯矩)解析式,显示为手写如下:\n');
pretty(S);
%第二部分
%是否继续运行程序
myloop=input('继续运行程序输入“1”,否则输入“0”\n');
ifmyloop
whilemyloop
xi=input('输入需要计算的点的值,并按回车键\n');
ifxi>x0|xi<x(n)
fprintf('现在开始计算输入点的插值函数值……\n');
else
fprintf('输入数值不在插值范围内,请重新输入\n');
xi=input('输入需要计算的点的值,并按回车键……\n');
end
%确定输入的数值应该使用哪个解析式
newx=[x0;x];
[r,suoy]=min(abs(newx-xi));
fprintf('输入点的插值函数值为:\n\n');fprintf('\t');
ifxi<=newx(suoy)
f=subs(S(suoy-1),X,xi);
else
f=subs(S(suoy),X,xi);
end
disp(f);
myloop=input('继续计算输入“1”,终止计算输入“0”\n');
end
else
return;
endfunction[x]=chase(a,b,c,d)
%追赶法解性方程组a是下三角b是对角线c是上三角d是常数项
%输入的abcd均为列向量
n=length(b);
u=zeros(n,1);
v=zeros(n,1);
x=zeros(n,1);
%追
v(1)=c(1)/b(1);u(1)=d(1)/b(1);
fori=2:n-1
v(i)=c(i)/(b(i)-v(i-1)*a(i-1));
u(i)=(d(i)-u(i-1)*a(i-1))/(b(i)-v
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 长春工业大学人文信息学院《BM安装工程计量》2023-2024学年第二学期期末试卷
- 南昌理工学院《现代控制》2023-2024学年第二学期期末试卷
- 昆明幼儿师范高等专科学校《金融学前沿动态》2023-2024学年第二学期期末试卷
- 信阳农林学院《台港暨海外华文文学研究》2023-2024学年第二学期期末试卷
- 西安体育学院《大数据机器学习》2023-2024学年第二学期期末试卷
- 潍坊工商职业学院《机器学习实验》2023-2024学年第二学期期末试卷
- 广东信息工程职业学院《UML及形式化建模》2023-2024学年第二学期期末试卷
- 山西旅游职业学院《化工原理(Ⅰ)》2023-2024学年第二学期期末试卷
- 湘潭医卫职业技术学院《信号分析与处理》2023-2024学年第二学期期末试卷
- 丽水职业技术学院《诗歌导读》2023-2024学年第二学期期末试卷
- 美丽的春天课件
- 2025年山东青岛自贸发展有限公司招聘笔试参考题库含答案解析
- 液化气罐的使用和安全防范
- 会计法律法规答题答案
- 2024年山东外贸职业学院高职单招语文历年参考题库含答案解析
- 2025江苏常州溧阳市部分机关事业单位招聘编外人员78人历年高频重点提升(共500题)附带答案详解
- 2025年学校心理健康教育工作计划(三篇)
- 2025年教科版科学五年级下册教学计划(含进度表)
- 欧盟一般食品法Regulation-(EC)-No-178-2002中文翻译
- 2024届高考语文二轮复习诗歌专题训练文学短评类题型(含解析)
- 中国国际大学生创新大赛与“挑战杯”大学生创业计划竞赛(第十一章)大学生创新创业教程
评论
0/150
提交评论