网站大量收购闲置独家精品文档,联系QQ:2885784924

多项式插值和次样条插值.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
多项式插值和次样条插值

已知某产品从1900年到2010年每隔10年的产量,用多项式插值和三次样条插值的方法,画出每隔一年的插值曲线的图形, 试计算并比较在不同方法下的2005年以及2015年的产量。 年份 1900 1910 1920 1930 1940 1950 产量 75.995 91.972 105.711 123.203 131.699 150.697 年份 1960 1970 1980 1990 2000 2010 产量 179.323 203.212 226.505 251.525 291.854 325.433 思想算法:多项式插值采用牛顿多项式插值法,该算法可以克服多项式插值和拉格朗日插值法的缺点,即:当用已知的n+1个数据点求出插值多项式后,又获得了新的数据点,要用它连同原有的n+1个数据点一起求出插值多项式,从原已计算出的n次插值多项式计算出新的n+1次插值多项式是很困难的,必须全部重新计算。而牛顿插值法可以克服这一缺点。 三次样条插值不仅在节点增多使子区间减少时,误差随之减少,也使曲线具有足够的光滑性。 Matlab程序如下 程序一:牛顿插值法 源程序名称Newton.m clear all; x=0:10:110; y=[75.995,91.972,105.711,123.203,131.699,150.697,179.323,203.212,226.505,251.525,291.854,325.433]; n=length(x);syms t; for k=2:n for i=n:-1:k y(i)=(y(i)-y(i-1))/(x(i)-x(i-k+1)); end; end; N=y(1); for i=2:n W=1; for j=1:(i-1) W=W*(t-x(j)); end; N=N+y(i)*W; end; N=expand(N); ezplot(N,[0,120]); hold on; format short; Q=[]; for i=0:120 Q(i+1)=subs(N,t,i); end; T=0:120; plot(T,Q,^); title(产量随时间变化曲线); xlabel(T/时间); ylabel(Q/产量); N105=subs(N,t,105); N115=subs(N,t,115); 程序二:三次样条插值 源程序名称SPLINEM.m clear all; x=0:10:110; y=[75.995,91.972,105.711,123.203,131.699,150.697,179.323,203.212,226.505,251.525,291.854,325.433]; n=length(x);syms t; for i=1:n p(i)=y(i); end; for k=2:3 for i=n:-1:k p(i)=(p(i)-p(i-1))/(x(i)-x(i+1-k)); end; end; h(2)=x(2)-x(1); for i=2:(n-1) h(i+1)=x(i+1)-x(i); c(i)=h(i+1)/(h(i)+h(i+1)); a(i)=1-c(i); b(i)=2; p(i)=6*p(i+1); end; p(1)=0;p(n)=0;c(1)=0;b(1)=2;b(n)=2;a(n)=0; u(1)=b(1);z(1)=p(1); for k=2:n l(k)=a(k)/u(k-1);u(k)=b(k)-l(k)*c(k-1); z(k)=p(k)-l(k)*z(k-1); end; M(n)=z(n)/u(n); for k=(n-1):-1:1 M(k)=(z(k)-c(k)*M(k+1))/u(k); end; for i=2:n S(i)=M(i-1)*(x(i)-t)^3/(6*h(i))+M(i)*(t-x(i-1))^3/(6*h(i))+(y(i-1)-M(i-1)*h(i)^2/6)*(x(i)-t)/h(i)+(y(i)-M(i)*h(i)^2/6)*(t-x(

您可能关注的文档

文档评论(0)

panguoxiang + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档