matlab插值法,迭代法程序
迭代法matlab

迭代法matlab一、引言编程是计算机科学中非常重要的一部分,它能够帮助我们解决各种各样的问题。
在计算机科学中,迭代法(Iteration Method)是一种常用的解决数值问题的方法。
本文将详细介绍迭代法在MATLAB中的应用及其原理。
二、迭代法的原理迭代法是一种通过递归或循环计算来逼近方程解的方法。
它通常用于无法通过解析方法求解的问题,例如非线性方程、积分、微分方程等。
迭代法基于以下原理: 1. 初始值的选择:我们需要选择一个合适的初始值作为迭代的起点。
2. 迭代公式的确定:我们需要找到一个迭代公式(或更新规则),通过不断迭代来逼近方程的解。
3. 精度要求的设定:我们需要设定一个精度要求,当迭代结果达到该精度要求时,迭代可以停止。
三、迭代法在MATLAB中的应用MATLAB是一款功能强大的科学计算软件,它提供了丰富的数学函数和工具箱,方便我们进行数值计算。
下面是迭代法在MATLAB中的常见应用场景和示例代码。
3.1 解非线性方程迭代法可用于解非线性方程。
例如,我们要解方程f(x) = 0,我们可以通过不断迭代来逼近方程的解。
以下是一个示例代码:function [x] = iterationMethod(f, x0, epsilon, maxIter)% f: 方程的函数句柄% x0: 初始值% epsilon: 精度要求% maxIter: 最大迭代次数x = x0;iter = 0;while iter < maxIterx_new = f(x); % 迭代公式if abs(x_new - x) < epsilonbreak;endx = x_new;iter = iter + 1;endif iter == maxIterdisp('迭代次数已达到最大值,未能满足精度要求!');elsedisp(['迭代成功,解为:', num2str(x)]);endend3.2 求解积分迭代法还可用于求解积分。
matlab迭代法求解方程

matlab迭代法求解方程在MATLAB中,可以使用迭代法来求解方程。
迭代法是一种通过反复迭代逼近方程解的方法。
下面我将从多个角度全面回答你关于MATLAB迭代法求解方程的问题。
首先,迭代法的基本思想是通过不断迭代一个初始猜测值,使得迭代序列逐渐趋近方程的解。
在MATLAB中,可以使用循环结构来实现迭代过程。
一般来说,迭代法需要满足收敛条件,即迭代序列能够收敛到方程的解。
常见的迭代法包括简单迭代法、牛顿迭代法和割线法等。
其次,我将介绍一种常见的迭代法——简单迭代法(也称为不动点迭代法)。
简单迭代法的基本思想是将方程转化为等价的不动点形式,即将方程f(x) = 0转化为x = g(x)的形式。
然后,通过迭代序列x_{n+1} = g(x_n)来逼近方程的解。
在MATLAB中,可以通过编写一个循环结构来实现简单迭代法。
下面是一个使用简单迭代法求解方程的MATLAB代码示例:matlab.function x = simple_iteration(g, x0, tol, max_iter)。
% 简单迭代法求解方程。
% 输入,g为迭代函数,x0为初始猜测值,tol为容差,max_iter为最大迭代次数。
% 输出,x为方程的解。
x = x0; % 初始猜测值。
iter = 0; % 迭代次数。
while abs(g(x) x) > tol && iter < max_iter.x = g(x); % 迭代计算下一个近似解。
iter = iter + 1; % 迭代次数加1。
end.if iter == max_iter.disp('迭代次数超过最大迭代次数,未找到解');else.disp(['迭代次数为,', num2str(iter)]);disp(['方程的解为,', num2str(x)]);end.end.在上述代码中,g为迭代函数,x0为初始猜测值,tol为容差,max_iter为最大迭代次数。
matlab中的迭代算法

matlab中的迭代算法迭代算法在matlab中的应用迭代算法是一种通过多次重复计算来逼近解的方法,它在matlab中得到了广泛的应用。
在本文中,我们将介绍一些常见的迭代算法,并探讨它们在matlab中的实现和应用。
1. 二分法二分法是一种简单而直观的迭代算法,它通过将问题的解空间一分为二,并根据中间点的取值来确定解所在的子空间。
在matlab中,可以使用while循环来实现二分法。
首先,需要指定解空间的上下界,然后通过计算中间点的值来判断解所在的子空间,并更新解空间的上下界。
重复这个过程,直到解的精度满足要求为止。
2. 牛顿迭代法牛顿迭代法是一种用于求解方程的迭代算法,它利用函数的局部线性近似来逼近方程的解。
在matlab中,可以使用while循环来实现牛顿迭代法。
首先,需要给定一个初始点,然后根据函数的一阶和二阶导数来计算下一个点的值。
重复这个过程,直到解的精度满足要求为止。
3. 高斯-赛德尔迭代法高斯-赛德尔迭代法是一种用于求解线性方程组的迭代算法,它通过不断更新近似解来逼近方程的解。
在matlab中,可以使用while循环和矩阵运算来实现高斯-赛德尔迭代法。
首先,需要给定一个初始解向量,然后根据方程组的系数矩阵和常数向量来计算下一个解向量的值。
重复这个过程,直到解的精度满足要求为止。
4. 迭代法求特征值迭代法也可以用于求解矩阵的特征值和特征向量。
在matlab中,可以使用while循环和矩阵运算来实现迭代法求特征值。
首先,需要给定一个初始特征向量,然后根据矩阵的幂来计算下一个特征向量的值。
重复这个过程,直到特征向量的变化小于某个阈值为止。
5. 迭代法求最优化问题除了求解方程和矩阵相关的问题,迭代算法还可以用于求解最优化问题。
在matlab中,可以使用while循环和梯度计算来实现迭代法求最优化问题。
首先,需要给定一个初始解向量,然后根据目标函数的梯度来计算下一个解向量的值。
重复这个过程,直到解的精度满足要求为止。
matlab中的迭代算法

matlab中的迭代算法Matlab中的迭代算法迭代算法是一种通过重复应用某个过程或规则来解决问题的方法。
在Matlab中,迭代算法广泛应用于数值计算、优化问题、图像处理等领域。
本文将介绍几种常见的迭代算法,并通过实例来演示其应用。
一、二分法二分法是一种简单而有效的迭代算法,用于求解函数的根。
其基本思想是通过将区间逐渐缩小,不断逼近根的位置。
具体步骤如下:1. 选择一个初始区间[a, b],使得f(a)和f(b)异号;2. 计算区间的中点c=(a+b)/2;3. 判断f(c)的符号,并更新区间的边界;4. 重复步骤2和3,直到满足精度要求。
二分法的优点是简单易懂,但收敛速度相对较慢。
以下是一个使用二分法求解方程x^2-2=0的示例代码:```matlaba = 1;b = 2;tol = 1e-6;while abs(b-a) > tolc = (a + b) / 2;if (c^2 - 2) * (a^2 - 2) < 0b = c;elsea = c;endendroot = (a + b) / 2;disp(root);```二、牛顿法牛顿法是一种迭代算法,用于求解非线性方程和最优化问题。
其基本思想是通过利用函数的局部线性近似,逐步逼近根或最优解。
具体步骤如下:1. 选择一个初始点x0;2. 计算函数f在点x0处的导数f'(x0);3. 计算切线方程的解,即x1 = x0 - f(x0)/f'(x0);4. 重复步骤2和3,直到满足精度要求。
牛顿法的优点是收敛速度快,但对初始点的选择较为敏感。
以下是一个使用牛顿法求解方程x^2-2=0的示例代码:```matlabx0 = 1;tol = 1e-6;while abs(x1 - x0) > tolx1 = x0 - (x0^2 - 2) / (2 * x0);x0 = x1;endroot = x1;disp(root);```三、迭代法求解线性方程组迭代法也可以用于求解线性方程组Ax=b。
matlab数组插值程序

matlab数组插值程序在MATLAB中,数组插值是一种常见的操作,可以使用interp1函数来实现。
interp1函数可以对一维数据进行插值操作,以下是一个简单的示例程序,演示了如何在MATLAB中进行数组插值操作:matlab.% 创建原始数据。
x = 1:5; % 原始数据的x坐标。
y = [3 6 2 8 4]; % 原始数据的y坐标。
% 创建插值的新x坐标。
xq = 1:0.1:5; % 创建新的x坐标,间隔为0.1。
% 使用interp1进行线性插值。
yq_linear = interp1(x, y, xq, 'linear'); % 线性插值。
% 使用interp1进行三次样条插值。
yq_spline = interp1(x, y, xq, 'spline'); % 三次样条插值。
% 绘制原始数据和插值结果。
plot(x, y, 'o', xq, yq_linear, '-', xq, yq_spline, '--');legend('原始数据', '线性插值', '三次样条插值');在这个示例程序中,我们首先创建了原始数据x和y,然后创建了新的x坐标xq,接着使用interp1函数进行线性插值和三次样条插值,最后将原始数据和插值结果绘制在同一张图上进行对比。
需要注意的是,interp1函数还可以进行其他类型的插值,比如最近邻插值、分段线性插值等,具体可以根据实际需求选择合适的插值方法。
除了interp1函数,MATLAB还提供了其他一些用于数组插值的函数,比如interp2(用于二维数据的插值)、interpn(用于多维数据的插值)等,可以根据具体情况选择合适的插值函数进行操作。
总之,MATLAB提供了丰富的插值函数,可以满足不同数据插值的需求,通过灵活运用这些函数,可以实现对数组的高效插值操作。
简单迭代法matlab例题程序

一、引言在数学建模和计算机编程中,简单迭代法是一种常用的求解方程近似解的方法。
其原理是通过不断迭代计算,逼近实际的解。
在Matlab 编程中,简单迭代法也是一种常见的应用。
本文将介绍简单迭代法的原理,并给出在Matlab中实现简单迭代法的例题程序。
二、简单迭代法原理1. 简单迭代法的基本思想是将需要求解的方程转化为迭代形式,即 x = g(x),然后通过不断迭代计算得到方程的近似解。
2. 简单迭代法的收敛条件是 |g'(x)| < 1,即迭代函数的导数的绝对值小于1时,迭代过程才能收敛。
3. 简单迭代法的收敛速度取决于迭代函数的选择,通常可以通过调整迭代函数来提高收敛速度。
三、Matlab中的简单迭代法实现在Matlab中,可以通过编写脚本文件来实现简单迭代法。
下面给出一个简单的例题:求解方程 x^2 - 3x + 2 = 0 的近似解。
4. 以下是Matlab中实现简单迭代法的脚本文件示例:```matlab定义迭代函数g = (x) 3*x - x^2;设置迭代初值和迭代次数x0 = 0.5;N = 100;迭代计算for k = 1:Nx = g(x0);fprintf('第d次迭代,近似解为:.10f\n', k, x);if abs(x - x0) < 1e-8 判断迭代是否收敛break;endx0 = x;end```5. 通过运行上述脚本文件,即可得到方程 x^2 - 3x + 2 = 0 的近似解。
四、实例分析通过上述例题程序的运行结果可以看出,简单迭代法在Matlab中的实现比较简单直观。
但是需要注意的是,迭代函数的选择和迭代初值的设定对最终的近似解都会产生影响,需要经过一定的调试和优化。
五、总结简单迭代法是一种常用的求解方程近似解的方法,在Matlab编程中也有着广泛的应用。
通过本文的介绍和示例程序,相信读者已经对简单迭代法在Matlab中的实现有了更深入的了解。
插值法,迭代法matlab程序

数值分析作业姓名学号学院专业2013年12月16日1.用MATLAB编程实现langrage插值多项式:syms xx0=[-2,-1,0,1];y0=[3,1,1,6];n=length(x0);for i=1:na=1;for j=1:nif j~=ia=expand(a*(x-x0(j)));endendb=1;for k=1:nif k~=ib=b*(x0(i)-x0(k));endendA(i)=expand(a/b);endL=0;for p=1:nL=L+y0(p)*A(p);endL>>LanguageL=x^3/2+(5*x^2)/2+2*x+12.牛顿插值多项式程序function[p2,z]=newTon(x,y,t)%输入参数中x,y为元素个数相等的向量,t为待估计的点,可以为数字或向量。
%输出参数中p2为所求得的牛顿插值多项式,z为利用多项式所得的t的函数值。
n=length(x);chaS(1)=y(1);for i=2:nx1=x;y1=y;x1(i+1:n)=[];y1(i+1:n)=[];n1=length(x1);s1=0;for j=1:n1t1=1;for k=1:n1if k==jcontinue;elset1=t1*(x1(j)-x1(k));endends1=s1+y1(j)/t1;endchaS(i)=s1;endb(1,:)=[zeros(1,n-1)chaS(1)];cl=cell(1,n-1);for i=2:nu1=1;for j=1:i-1u1=conv(u1,[1-x(j)]);cl{i-1}=u1;endcl{i-1}=chaS(i)*cl{i-1};b(i,:)=[zeros(1,n-i),cl{i-1}];endp2=b(1,:);for j=2:np2=p2+b(j,:);endif length(t)==1rm=0;for i=1:nrm=rm+p2(i)*t^(n-i);endz=rm;elsek1=length(t);rm=zeros(1,k1);for j=1:k1for i=1:nrm(j)=rm(j)+p2(i)*t(j)^(n-i);endz=rm;endendx=[-1125];y=[-77-435];t=1;[u,v]=newTon(x,y,t)>>[u,v]=newton(x,y,t)u=2-10510v=7则所求得的牛顿多项式为:2*x^3-10x^2+5*x+103.Matlab程序三次样条插值函数clearclcx=[12346]y=[00.693147 1.09861 1.38629 1.79176]n=length(x);for i=1:n-1h(i)=x(i+1)-x(i);endfor i=1:n-2k(i)=h(i+1)/(h(i)+h(i+1));u(i)=h(i)/(h(i)+h(i+1));endfor i=1:n-2gl(i)=3*(u(i)*(y(i+2)-y(i+1))/h(i+1)+k(i)*(y(i+1)-y(i))/h(i)); endg0=3*(y(2)-y(1))/h(1);g00=3*(y(n)-y(n-1))/h(n-1);g=[g0gl g00];g=transpose(g)k1=[k1];u1=[1u];Q=2*eye(5)+diag(u1,1)+diag(k1,-1)m=transpose(Q\g)syms X;for i=1:n-1p1(i)=(1+2*(X-x(i))/h(i))*((X-x(i+1))/h(i))^2*y(i);p2(i)=(1-2*(X-x(i+1))/h(i))*((X-x(i))/h(i))^2*y(i+1);p3(i)=(X-x(i))*((X-x(i+1))/h(i))^2*m(i);p4(i)=(X-x(i+1))*((X-x(i))/h(i))^2*m(i+1);p(i)=p1(i)+p2(i)+p3(i)+p4(i);p(i)=simple(p(i));ends1=p(1)s2=p(2)s3=p(3)s4=p(4)for k=1:4for z=x(k):0.001:x(k+1)q=eval(subs(p(k),'X','z'));plot(z,q,'b')hold onendendgrid onlegend('eval')title('sysm')xlabel('x')ylabel('p')x=12346y=00.6931 1.0986 1.3863 1.7918g= 2.07941.64791.03970.77810.6082Q=2.0000 1.00000000.5000 2.00000.50000000.5000 2.00000.50000000.6667 2.00000.3333000 1.0000 2.0000 m=0.76290.55370.31810.25350.17744.牛顿迭代法求多项式根syms xf=x-cos(x);df=diff(f,x);eps=1e-6;x0=1;cnt=0;MAXCNT=20;%最大循环次数while cnt<MAXCNT%防止无限循环x1=x0-subs(f,x,x0)/subs(df,x,x0);%去掉这个分号,可以看到迭代过程.if(abs(x1-x0)<eps)break;endx0=x1;cnt=cnt+1;endif cnt==MAXCNTdisp'不收敛'elsevpa(x1,8)end>>Untitledans=0.73908513。
matlab迭代函数程序

matlab迭代函数程序Matlab是一种高级的数学软件,其内置了许多迭代函数,可以帮助用户更方便地进行数值计算和数据分析。
本文将介绍一些常用的Matlab迭代函数及其应用,希望能够对读者有所帮助。
一、for循环for循环是Matlab中最基本的迭代函数之一,其语法格式为: for 循环变量=初始值:步长:终止值循环体end其中,循环变量是一个标量或向量,初始值、步长和终止值都是数值。
循环体中的语句将会被重复执行,直到循环变量达到终止值为止。
下面是一个简单的例子,计算1到10的累加和:sum = 0;for i = 1:10sum = sum + i;enddisp(sum);输出结果为55,即1+2+3+...+10的和。
二、while循环while循环是另一种常用的迭代函数,其语法格式为:while 条件循环体end其中,条件可以是任何能够返回逻辑值的表达式,循环体中的语句将会被重复执行,直到条件为假为止。
下面是一个简单的例子,计算1到10的累加和:sum = 0;i = 1;while i <= 10sum = sum + i;i = i + 1;enddisp(sum);输出结果为55,与for循环的结果相同。
三、递归函数递归函数是一种特殊的函数,其定义中包含对自身的调用。
在Matlab中,递归函数的语法与普通函数相同,但需要注意避免死循环。
下面是一个递归函数的例子,计算n的阶乘:function f = factorial(n)if n == 0f = 1;elsef = n * factorial(n-1);endend该函数首先判断n是否为0,若是则返回1;否则返回n乘以n-1的阶乘。
例如,计算5的阶乘可以使用以下语句:disp(factorial(5));输出结果为120。
四、向量化运算向量化运算是Matlab的一大特色,可以大大提高计算效率。
其基本思想是将循环语句转化为矩阵运算,避免了循环带来的额外开销。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数值分析作业姓名王建忠学号132080202006学院能源与动力工程专业机械电子工程2013年12月16日grange插值多项式程序function f=nalagr(x,y,xx)%x为节点向量%y为节点函数值%xx是插值点syms sif(length(x)==length(y))n=length(x);elsedisp('x和y的维数不相等!');return;endf=0.0;for(i=1:n)l=y(i);for(j=1:i-1)l=l*(s-x(j))/(x(i)-x(j));end;for(j=i+1:n)l=l*(s-x(j))/(x(i)-x(j));%计算拉格朗日基函数end;f=f+l;%计算拉格朗日插值函数simplify(f);if(i==n)if(nargin==3)f=subs(f,'s');%计算插值点的函数值elsef=collect(f);%将插值多项式展开f=vpa(f,6);%将插值多项式的系数化成6位精度的小数endendend>>x=[-2,-1,0,1];%已知节点向量y=[3,1,1,6];%节点函数值向量f=nalagr(x,y)f=0.5*s^3+ 2.5*s^2+ 2.0*s+ 1.0>>f=nalagr(x,y,0)f=1>>2.牛顿插值多项式程序function[p2,z]=newTon(x,y,t)%输入参数中x,y为元素个数相等的向量,t为待估计的点,可以为数字或向量。
%输出参数中p2为所求得的牛顿插值多项式,z为利用多项式所得的t的函数值。
n=length(x);chaS(1)=y(1);for i=2:nx1=x;y1=y;x1(i+1:n)=[];y1(i+1:n)=[];n1=length(x1);s1=0;for j=1:n1t1=1;for k=1:n1if k==jcontinue;elset1=t1*(x1(j)-x1(k));endends1=s1+y1(j)/t1;endchaS(i)=s1;endb(1,:)=[zeros(1,n-1)chaS(1)];cl=cell(1,n-1);for i=2:nu1=1;for j=1:i-1u1=conv(u1,[1-x(j)]);cl{i-1}=u1;endcl{i-1}=chaS(i)*cl{i-1};b(i,:)=[zeros(1,n-i),cl{i-1}];endp2=b(1,:);for j=2:np2=p2+b(j,:);endif length(t)==1rm=0;for i=1:nrm=rm+p2(i)*t^(n-i);endz=rm;elsek1=length(t);rm=zeros(1,k1);for j=1:k1for i=1:nrm(j)=rm(j)+p2(i)*t(j)^(n-i);endz=rm;endend>>x=[-1,1,2,5];y=[-7,7,-4,35];t=1;[u,v]=newTon(x,y,t)u=2-10510%多项式系数v=7%插值点函数值>>3.牛顿迭代法求多项式根%主程序:function[k,x,wuca,yx]=newtondiedai(x0,e)k=1;yx1=fun(x0);yx2=fun1(x0);x1=x0-yx1/yx2;while abs(x1-x0)>ex0=x1;yx1=fun(x0);yx2=fun1(x0);k=k+1;x1=x1-yx1/yx2;endk;x=x1;wuca=abs(x1-x0)/2;yx=fun(x);end%分程序1:function y1=fun(x)y1=x-cos(x);%待求解多项式end%分程序2:function y2=fun1(x)y2=1+sin(x);%函数fun(x)的导数end%分程序2:function y2=fun1(x)y2=1+sin(x);%函数fun(x)的导数end>>[k,x,wuca,yx]=newton(1,10^-5)k=4x=0.7391wuca=3.4480e-10yx=04.三次样条插值函数Matlab程序function[]=spline3(X,Y,dY,x0,m)N=size(X,2);s0=dY(1);sN=dY(2);interval=0.025;disp('x0为插值点')x0h=zeros(1,N-1);for i=1:N-1h(1,i)=X(i+1)-X(i);endd(1,1)=6*((Y(1,2)-Y(1,1))/h(1,1)-s0)/h(1,1);d(N,1)=6*(sN-(Y(1,N)-Y(1,N-1))/h(1,N-1))/h(1,N-1);for i=2:N-1d(i,1)=6*((Y(1,i+1)-Y(1,i)))/(h(1,i)-(Y(1,i)-Y(1,i-1)))/h(1,i-1) /(h(1,i)+h(1,i-1));endmu=zeros(1,N-1);md=zeros(1,N-1);md(1,N-1)=1;mu(1,1)=1;for i=1:N-2u=h(1,i+1)/(h(1,i)+h(1,i+1));mu(1,i+1)=u;md(1,i)=1-u;endp(1,1)=2;q(1,1)=mu(1,1)/2;for i=2:N-1p(1,i)=2-md(1,i-1)*q(1,i-1);q(1,i)=mu(1,i)/p(1,i);endp(1,N)=2-md(1,N-1)*q(1,N-1);y=zeros(1,N);y(1,1)=d(1)/2;for i=2:N y(1,i)=(d(i)-md(1,i-1)*y(1,i-1))/p(1,i);endx=zeros(1,N);x(1,N)=y(1,N);for i=N-1:-1:1x(1,i)=y(1,i)-q(1,i)*x(1,i+1);endfprintf('M为三对角方程的解\n');M=xfprintf('\n');syms t;digits(m);for i=1:N-1pp(i)=M(i)*(X(i+1)-t)^3/(6*h(i))+M(i+1)*(t-X(i))^3/(6*h(i))+(Y(i)-M(i) *h(i)^2/6)*(X(i+1)-t)/h(i)+(Y(i+1)-M(i+1)*h(i)^2/6)*(t-X(i))/h(i);pp(i)=simplify(pp(i));coeff=sym2poly(pp(i));if length(coeff)~=4tt=coeff(1:3);coeff(1:4)=0;coeff(2:4)=tt;endif x0>X(i)&x0<X(i+1)L=i;y0=coeff(1)*x0^3+coeff(2)*x0^2+coeff(3)*x0+coeff(4);endval=X(i):interval:X(i+1);for k=1:length(val)fval(k)=coeff(1)*val(k)^3+coeff(2)*val(k)^2+coeff(3)*val(k)+coeff(4); endif mod(i,2)==1plot(val,fval,'r+')else plot(val,fval,'b.')endhold onclear val fvalans=sym(coeff,'d');ans=poly2sym(ans,'t');fprintf('在区间[%f,%f]内\n',X(i),X(i+1));fprintf('三次样条函数S(%d)=',i);pretty(ans);endfprintf('x0所在区间为[%f,%f]\n',X(L),X(L+1));fprintf('函数在插值点x0=%f的值为\n',x0);y0>>X=[12346];Y=[00.6931471.098611.38629 1.79176];dY=[11/6];x0=5;m=5;spline3(X,Y,dY,x0,m)x0为插值点x0=5M为三对角方程的解M=-2.1818 2.52260.01970.3019-0.2050在区间[1.000000,2.000000]内三次样条函数S(1)=320.78407t- 3.4431t+ 5.5341t- 2.875在区间[2.000000,3.000000]内三次样条函数S(2)=32-0.41715t+ 3.7642t-10.49t+9.9528在区间[3.000000,4.000000]内三次样条函数S(3)=320.047026t-0.41338t+ 1.4414t-0.77484在区间[4.000000,6.000000]内三次样条函数S(4)=32-0.042241t+0.65781t- 3.1651t+ 6.2252 x0所在区间为[4.000000,6.000000]函数在插值点x0=5.000000的值为y0=1.5648。