Matlab解决简单4次牛顿差值,Matlab插值法

2024-01-20 08:50

本文主要是介绍Matlab解决简单4次牛顿差值,Matlab插值法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实验目的:

1.Matlab中多项式的表示及多项式运算

2.用Matlab实现拉格朗日及牛顿插值法

3.用多项式插值法拟合数据

实验要求:

1.掌握多项式的表示和运算

2.拉格朗日插值法的实现(参见吕同富版教材)

3.牛顿插值法的实现(参见吕同富版教材)

实验内容:

1.多项式的表达式和创建;多项式的四则运算、导数与积分。

2.用Matlab实现拉格朗日及牛顿插值法。

3.用多项式插值法拟合数据。

6e9099745cfccb09a1a3889324c62139.png

实验步骤:

1.多项式的表达式,MATLAB中使用以为向量来表示多项式,将多项式的系数按照降幂次序存放在向量中。多项式P(x)的具体表示方法:

86c8a42ca64bad91a1c400c1b57eb1a8.png的系数构成向量为:

c45d9312077b99a79754aa708205b5b1.png

。示例如下:

6eddeba9b5d109e673c831ea5c39d452.png

975343320c5c41233fea5031be35179d.png

将向量表示的多项式用字符串输出的通用函数示例:

a4daddcd3b6d45a7277dac622c4c3f0a.png

例子

14ef03aff51e0a0efd0123a3bf02fae1.png运行示例:

7c6de35202102a86dfc7aab1bf1f6e2b.png

多项式的加法:

c9cef752c8185abe53ce0f8172014009.png

结果是

39e8aeabb3a521c38ce8b3890e467356.png

多项式乘法:

3ff259500f530864ed21ae9961f57cbc.png

结果是

12ce1984af18b464200de8223f48096e.png

多项式除法:

ac6db9cc1449c6892b99f5384988f7a0.png

多项式导数:

fc0f919ff60db7303f61def003558af8.png

792078cf10aa7e64d2ed5c7f321b9554.png

2.用Matlab实现拉格朗日,拉格朗日代码:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 function yi=Lagrange(x,y,xi)

2 m=length(x);n=length(y);p=length(xi);

3 if m~=n

4 error('向量x与y的长度必须一致');

5 end

6 s=0;

7 for k=1:n

8 t=ones(1,p);

9 for j=1:n

10 if j~=k

11 t=t.*(xi-x(j))./(x(k)-x(j));

12 end

13 end

14 s=s+t.*y(k);

15 end

16 yi=s;

17 end

Lagrange

运行示例:

137fd1fe9b69ca96c9ac7d241820764b.png

555ce07c3548250d1fb26f63b131afda.png

9da96c1cf8c35c6722737acb8c11353a.png

7186dc9c37f41cf1eb1159b2cc103590.png

d6c37ac02b4f61946c0129dc77b3917d.png

96998979cfae27eca4b9e7a0a65718e3.png

牛顿插值法代码:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 function yi=newtonint(x,y,xi)

2 m=length(x);n=length(y);

3 if m~=n

4 error('向量x与y的长度必须一致');

5 end

6 A=zeros(n);

7 A(:,1)=y;

8 for j=2:n%j为列标

9 for i=1:(n-j+1) %i为行标

10 A(i,j)=(A(i+1,j-1)-A(i,j-1))/(x(i+j-1)-x(i));%计算差商表

11 end

12 end

13 %根据差商表,求对应的牛顿插值多项式在x=xi处的值yi

14 N(1)=A(1,1);

15 for j=2:n

16 T=1;

17 for i=1:j-1

18 T=T*(xi-x(i));

19 end

20 N(j)=A(1,j)*T;

21 end

22 yi=sum(N); %将x=xi带入牛顿插值多项式,得到的yi的值

23 %A 输出差商表

24 end

newtonint

运行实例:

9d80017996ddb9105b9e9ec2b01ad8af.png

等距节点的牛顿向后插值代码:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 function yi=newtonint1(x,y,xi)

2 h=x(2)-x(1);t=(xi-x(1))/h;

3 n=length(y);Y=zeros(n);Y(:,1)=y';

4 for k=1:n-1

5 Y(:,k+1)=[diff(y',k);zeros(k,1)];

6 end

7 yi=Y(1,1);

8 for i=1:n-1

9 z=t;

10 for k=1:i-1

11 z=z*(t-k);

12 end

13 yi=yi+Y(1,i+1)*z/prod([1:i]);

14 end

newtonint1

运行实例:

67080b8f7619b9ac57dbc60945ca64cc.png

等距节点的牛顿向前插值代码:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 function yi=newtonint2(x,y,xi)

2 n=length(x);h=x(n)-x(n-1);t=(x(n)-xi)/h;

3 n=length(y);Y=zeros(n);Y(:,1)=y';

4 for k=1:n-1

5 Y(:,k+1)=[zeros(k,1);diff(y',k)];

6 end

7 h=x(n)-x(n-1);t=(x(n)-xi)/h;yi=Y(n,1);

8 for i=1:n-1

9 z=t;

10 for k=1:i-1

11 z=z*(t-k);

12 end

13 yi=yi+Y(n,i+1)*(-1)^i*z/prod([1:i]);

14 end

newtonint2

运行示例:

23fa2a2bd8079cef745d74864b69afbd.png

3.使用4次牛顿插值多项式插值,并作图:

20e245e5dafded156026ef61f80f86a9.png

解:由4次牛顿插值多项式,

970f774fd93c110f0be458ddcc8efee0.png

求上述多项式的系数:(修改newtonint.m代码,得到差商表),代码如下:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 function B=newtonint4(x,y)

2 m=length(x);n=length(y);

3 if m~=n

4 error('向量x与y的长度必须一致');

5 end

6 A=zeros(n);

7 A(:,1)=y;

8 for j=2:n%j为列标

9 for i=1:(n-j+1) %i为行标

10 A(i,j)=(A(i+1,j-1)-A(i,j-1))/(x(i+j-1)-x(i));%计算差商表

11 end

12 end

13 B=A;

14 end

newtonint4

代入数据得到差商表:

0.98

-0.3

-0.625

-0.2083

-0.5208

0.92

-0.55

-0.75

-0.625

0

0.81

-0.85

-1.125

0

0

0.64

-1.3

0

0

0

0.38

0

0

0

0

已知,第一行的便是插值多项式的系数,代入插值多项式:

0cc04309e8641f79f66f89ff6e6687d6.png

并作出图像:

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 x0=[0.2 0.4 0.6 0.8 1.0];

2 y0=[0.98 0.92 0.81 0.64 0.38];

3 plot(x0,y0,'b-o')

4 hold on

5 k=0:1:10;

6 x=0.2+0.08*k;

7 for i=1:1:11

8 y(i)=0.98-0.3*(x(i)-0.2)-0.625*(x(i)-0.2)*(x(i)-0.4)-0.2083333*(x(i)-0.2)*(x(i)-0.4)*(x(i)-0.6)-0.520833333*(x(i)-0.2)*(x(i)-0.4)*(x(i)-0.6)*(x(i)-0.8);

9 end

10 plot(x,y,'r-o');

11 legend('原图像','4次插值图像');

plot3

7d4e8894f6b4d9826e6037179865d9a1.png

小结:

在编写牛顿插值的代码时,我遇到了超出元组索引的问题。我在MATLAB的提示下(它的提示是英语),如图:

613b79bdde290c5a597bb476502f58ed.png

这个f是使用迭代来求差商的,但是出现了问题。我根据它的提示创建了一个全零数组用于存储运算得到的差商,在某种程度上解决了这个问题。

在解决第3题时,我特意编写了一个算差商的程序和一个4次牛顿插值多项式代入数据画图的程序。差商的程序是修改第2题的牛顿插值程序得到的,这在一定程度上说明,一个程序的功能是可以分开的同时也可以写在一起的。但在写4次多项式代入画图的程序时,并没有参考的我,只能回看书本关于4次牛顿插值的知识,我得到了这个牛顿插值多项式的公式,并发现它的关键就是每一项的系数,而那些系数就是算得的差商,所以,很快,我就写出了4次多项式代入画图的程序。很开心的是,算得的多项式拟合得很好。

标签:yi,xi,end,插值法,多项式,牛顿,插值,Matlab

来源: https://www.cnblogs.com/jianle23/p/12817734.html

这篇关于Matlab解决简单4次牛顿差值,Matlab插值法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/625459

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

速盾高防cdn是怎么解决网站攻击的?

速盾高防CDN是一种基于云计算技术的网络安全解决方案,可以有效地保护网站免受各种网络攻击的威胁。它通过在全球多个节点部署服务器,将网站内容缓存到这些服务器上,并通过智能路由技术将用户的请求引导到最近的服务器上,以提供更快的访问速度和更好的网络性能。 速盾高防CDN主要采用以下几种方式来解决网站攻击: 分布式拒绝服务攻击(DDoS)防护:DDoS攻击是一种常见的网络攻击手段,攻击者通过向目标网