`
_Jason_
  • 浏览: 43171 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

lagrange,Newton插值计算(c/c++实现)

    博客分类:
  • Cust
阅读更多

***********************Sample1-lagrange*************************
#include<iostream>
#include<cmath>
using namespace std;

int lagrange(double *px,double *py,double *pcoeff,int iNum)
{ //px 存储已知点横坐标值,py 存储已知点纵坐标值,pcoeff 带回
  //多项式的系数,iNum 为已知点个数
  //以下变量名皆对应公式所用字母
double *pk,*ptemp_coeff;
int i,j,k,kk; pk=new double [iNum];
ptemp_coeff=new double [iNum];
//初始化系数数组
for(i=0;i<iNum;i++) {
pcoeff[i]=0.0;
ptemp_coeff[i]=0.0;
}
//以下为公式(1)
for(i=0;i<iNum;i++) {
pk[i]=1.0;
for(j=0;j<iNum;j++) {
if(i!=j) {
pk[i]*=px[i]-px[j];
}
}
}
//i 循环为公式(3) 循环为公式(2) ,j
for(i=0;i<iNum;i++) {
ptemp_coeff[0]=1.0; //乘积因子 1.0
  for(j=0,k=0;j<iNum;j++) //乘以第 j 个因子
  {
  if(j!=i) {
    for(k++,kk=k;kk>0;kk--)
{
  ptemp_coeff[kk]-=ptemp_coeff[kk-1]*px[j];
}
  }
  }
  for(j=0;j<iNum;j++)//公式(3) ,求和
  {
  pcoeff[j]+=py[i]*ptemp_coeff[j]/pk[i];
  ptemp_coeff[j]=0.0;
  }
}
   delete pk,ptemp_coeff;
return 0;
}
double lagcaculate(double *pcoeff,double dxx,int iNum) {
//dxx 表示需要估计函数值处的横坐标
//由拉格朗日插值公式计算函数值
//返回计算所得函数值
double dsum;
int i;
dsum=0.0;
for(i=0;i<iNum;i++) {
dsum=dsum*dxx+pcoeff[i];
}
return dsum;
}
int main() {
int iNum,i,iisrandom;
double *px,*py,*pcoeff;
cout<<"本程序求解拉格朗日插值求解函数近似值" <<endl<<"请输入已知点个数:"<<endl; cin>>iNum; cout<<"是否进行自动测试(测试函数为正弦函数),是输入 1,否输入 0:";
cin>>iisrandom;
px=new double [iNum];
py=new double [iNum];
pcoeff=new double [iNum];
if(iisrandom==0) {
cout<<"请输入 iNum 个已知点的横坐标:"<<endl;
for(i=0;i<iNum;i++) {
cin>>px[i];
}
cout<<"请输入 iNum 个已知点的纵坐标:"<<endl;
for(i=0;i<iNum;i++) {
cin>>py[i];
}
} else {
for(i=0;i<iNum;i++) { px[i]=i; py[i]=sin(i);
}
}
lagrange(px,py,pcoeff, iNum);
int testnum;
cout<<"输入测试值数量"; cin>>testnum;
double *pxvalue;
pxvalue=new double [testnum];
double *pyvalue;
pyvalue=new double [testnum];
cout<<"输入"<<testnum<<"个需要测试的值"<<endl;
for(i=0;i<testnum;i++) //输入 testnum 个需要求近似值的自变量值
{ cin>>pxvalue[i]; }
for(i=0;i<testnum;i++) //有拉格朗日插值公式计算近似值
{ pyvalue[i]=lagcaculate(pcoeff,pxvalue[i],iNum);
py[i]=sin(pxvalue[i]);
}
cout<<"拉格朗日公式求得的值"<<"    "<<"标准函数值为"<<endl;

for(i=0;i<testnum;i++) {
cout<<pyvalue[i]<<"     "<<py[i]<<endl;
}
delete px,py,pcoeff,pxvalue,pyvalue;
return 0;
}


***********************Sample2-lagrange&Newton***********************


#include<stdio.h>
#include<stdlib.h>
#include<iostream.h>
typedef struct data
{
float x;
float y;
}Data;//变量x和函数值y的结构
Data d[20];//最多二十组数据
float f(int s,int t)//牛顿插值法,用以返回插商
{
if(t==s+1)
  return (d[t].y-d[s].y)/(d[t].x-d[s].x);
else
        return (f(s+1,t)-f(s,t-1))/(d[t].x-d[s].x); 
}
//float Newton(float x,int count)
//{
// int n;
//while(1)
//{
//     cout<<"请输入n值(即n次插值):";//获得插值次数
//  cin>>n;
//  if(n<=count-1)// 插值次数不得大于count-1次
//  break;
// else
//   system("cls");
// }
//初始化t,y,yt。
// float t=1.0;
//float y=d[0].y;
// float yt=0.0;
//计算y值
//for(int j=1;j<=n;j++)
//{
// t=(x-d[j-1].x)*t;
// yt=f(0,j)*t;
  //cout<<f(0,j)<<endl;
//  y=y+yt;
//}
// return y;
//}
float lagrange(float x,int count)
{
float y=0.0;
for(int k=0;k<count;k++)//这儿默认为count-1次插值
{
  float p=1.0;//初始化p
  for(int j=0;j<count;j++)
  {//计算p的值
   if(k==j)continue;//判断是否为同一个数
   p=p*(x-d[j].x)/(d[k].x-d[j].x);
  }
  y=y+p*d[k].y;//求和
}
return y;//返回y的值
}
void main()
{
float x,y;
int count;
while(1)
{
  cout<<"请输入x[i],y[i]的组数,不得超过20组:";//要求用户输入数据组数
  cin>>count;
  if(count<=20)
   break;//检查输入的是否合法
  system("cls");
}
//获得各组数据
for(int i=0;i<count;i++)
{
      cout<<"请输入第"<<i+1<<"组x的值:";
      cin>>d[i].x;
      cout<<"请输入第"<<i+1<<"组y的值:";
      cin>>d[i].y;
   system("cls");
}
cout<<"请输入x的值:";//获得变量x的值
cin>>x;
while(1)
{
  int choice=3;
// cout<<"请您选择使用哪种插值法计算:"<<endl;
  //cout<<"              (0):退出"<<endl;
  //cout<<"              (1):Lagrange"<<endl;
// cout<<"              (2):Newton"<<endl;
// cout<<"输入你的选择:";
// cin>>choice;//取得用户的选择项
choice=1;
  //if(choice==2)
// {
//  cout<<"你选择了牛顿插值计算方法,其结果y为:";
//  y=Newton(x,count);break;//调用相应的处理函数
// }
  //      if(choice==1)
// {
   cout<<"拉格朗日插值计算方法,其结果为:";
   y=lagrange(x,count);
   break;//调用相应的处理函数
// }
  if(choice==0)
   break;
  system("cls");
  cout<<"输入错误!!!!"<<endl;
}
cout<<y<<endl;//输出最终结果
   
}

分享到:
评论

相关推荐

    newton插值计算方法作业

    此外,代码还包括了一个 `lagrange()` 函数,用于实现拉格朗日插值法,这是一种与Newton插值类似的插值方法,但其多项式形式略有不同。 #### 实践应用与交互式输入 代码中还包含了一个主函数 `main()`,它负责处理...

    CodeBlock :插值(Lagrange插值和Newton插值)

    这通常涉及定义函数来计算Lagrange或Newton插值多项式,并提供一个输入接口接收数据点和查询点。然后,你可以使用这些函数对给定的数据进行插值,并输出结果。 在处理实际问题时,选择Lagrange还是Newton插值通常取...

    MFC示例:Lagrange插值算法的实现

    本文将详细介绍如何使用C++编程语言,结合Microsoft Foundation Classes (MFC) 框架,在Visual Studio 2008环境下实现Lagrange插值算法。 首先,理解Lagrange插值的基本概念至关重要。Lagrange插值通过构造一组...

    C/C++写的拉格朗日Lagrange和牛顿Newton插值函数

    标准C语言编写的拉格朗日(Lagrange)和牛顿(Newton)插值函数。 VS2008,gcc编译通过

    C程序的插值.rar_newton_newton插值_插值_插值程序C++_插值算法

    综上所述,这个压缩包提供了Lagrange和Newton插值算法的C++实现,对于学习和理解数值计算中的插值方法具有实际价值。无论是为了研究、教学还是工程实践,掌握这些插值技术对于提升数值计算能力都是非常有益的。

    Lagrange插值

    Lagrange插值和Newton插值公式

    实现lagrange 和newton方法

    在C++中,你可以创建一个函数来计算每个Lagrange基多项式,然后将它们相加得到插值多项式。需要注意的是,Lagrange插值在处理大量数据时可能会导致数值不稳定,因为项之间的乘积可能会导致极大的结果。 **牛顿插值...

    数值分析实验(误差分析,Lagrange插值,高斯消去法解方程组

    1.掌握利用Lagrange插值法及Newton插值法求函数值并编程实现。 2.程序具有一定的通用性,程序运行时先输入节点的个数n,然后输入各节点的值( ),最后输入要求的自变量x的值,输出对应的函数值。 二、实验设备和...

    用Newton插值公式绘制曲线

    Newton插值公式,也称为Newton-forward或Newton-Lagrange插值,是数学中的一种插值方法,用于找到一个多项式函数,该函数精确地通过给定的一系列离散点。公式如下: \[ P_n(x) = f(x_0) + \frac{(x-x_0)}{x_1-x_0}...

    计算方法实验程序大全(基于C++)

    本资源"计算方法实验程序大全(基于C++)"聚焦于用C++编程语言实现的计算方法,尤其关注New迭代、二分法、Lagrange插值法、Newton插值法、复合梯形求积公式以及改进欧拉算法。这些算法是数值分析中的核心概念,对于...

    vc++实现数值插值计算

    本文将深入探讨如何使用VC++这一强大的C++开发环境来实现数值插值,尤其是拉格朗日(Lagrange)插值和牛顿(Newton)插值算法。 首先,让我们理解什么是插值。插值是一种数学方法,它的目标是找到一个函数,该函数...

    PB13011092-02.cpp.zip_数学计算_C/C++_

    这个压缩包"PB13011092-02.cpp.zip"显然包含了关于数学计算的一个具体实例,即利用C++实现Lagrange插值(Lagrange Interpolation)。Lagrange插值是一种在离散数据点上构造连续函数的方法,它在科学计算、工程分析...

    Newton插值法的程序设计与应用.pdf

    相比Lagrange插值法,牛顿插值法在增加新的插值节点时,由于仅影响部分项,因此在计算上显得更加高效。 在编程实现牛顿插值法的过程中,开发者常用C++或Matlab等高级编程语言。以C++为例,利用其强大的数值计算能力...

    昆明理工大学数值分析上机报告.docx

    《昆明理工大学数值分析上机报告》探讨了数值分析中的函数插值方法,主要涉及Lagrange插值、分段二次Lagrange插值、Newton插值以及曲线拟合的最小二乘法。这些方法在处理实际问题时,尤其是面对那些没有明确解析...

    三次样条插值 含源码 结果分析

    同时,Lagrange插值法和Newton插值法的计算结果也趋近于真实结果,但是在插值节点等距分布的情况下,计算结果的误差较大。这是因为Lagrange插值法和Newton插值法对插值节点的选择非常敏感,在插值节点等距分布的情况...

    数值计算-计算器

    在C++中,可以使用递归公式或者Lagrange多项式来实现Newton插值,这对于数据拟合和曲线拟合任务非常有用。 Rung-Kutta方法是常微分方程数值解的主流方法,特别是四阶Rung-Kutta方法,它通过在每个时间步长内进行多...

    插值法程序

    本文档主要介绍了一种实现插值法的C++程序代码,其中包括牛顿插值法(Newton Interpolation)和拉格朗日插值法(Lagrange Interpolation)。该程序允许用户输入一系列数据点,并根据这些数据点对未知点进行插值计算...

    数值分析实验误差分析.pdf

    2. 已知4个点的函数值,用Newton插值法求x=0.596时的函数值。 五、实验结果及分析 1. 拉格朗日插值结果:f(11°)=0.199369。 2. 牛顿插值结果:f(0.596)=0.631914。 六、思考题 无。 七、心得体会及实验改进...

    C 语言 做数值计算 Computing for Numerical Methods Using Visual C++

    1. 插值与拟合:插值用于找到一组数据点之间的函数关系,例如线性插值、多项式插值(如Lagrange插值和Newton插值)和样条插值。拟合则是找到最佳拟合数据的函数,如最小二乘法。 2. 微积分:包括数值微分(如有限差...

Global site tag (gtag.js) - Google Analytics