牛顿插值法(c++)
|
X |
Y |
|
0.40 |
0.41075 |
|
0.55 |
0.57815 |
|
0.65 |
0.69675 |
|
0.80 |
0.88811 |
|
0.90 |
1.02652 |
|
1.05 |
1.25382 |
#include
using namespace
std;
double
average_deviation(double* function_value,double*
independent_variable,int
end);
//声明均差函数
int main()
{
double
x[5]={0.40,0.55,0.65,0.80,0.90};
//用来存储已知x的值
double
y[5]={0.41075,0.57815,0.69675,0.88811,1.02652};
//用来存储已知y的值
double
result=0;
//用来保存最后的插值结果
double
input_x;
//插值的x值
double
polynomial;
//保存多项式的值
cout<<"通过插值得到的函数为:"<<endl;
for (int i=0;i<5;i++)
{
cout<<average_deviation(y,x,i);
for (int j=0;j
cout<<"*"<<"("<<"x-"<<x[j]<<")";
if (i<4)
cout<<"+";
}
cout<<endl;
cout<<"请输入插值的x值:";
cin>>input_x;
for (int i=0;i<5;i++)
{
polynomial=1;
for (int j=0;j
{
polynomial*=(input_x-x[j]);
}
result+=(average_deviation(y,x,i)*polynomial);
}
cout<<"插值得到的函数值为:"<<result<</span><</span>endl;
return 0;
}
double
average_deviation(double* function_value,double*
independent_variable,int end)
{
double*
function_value_f;
//function_value_f用来保存0到k-1的k阶均差
double*
function_value_b;
//function_value_f用来保存1到k的k阶均差
double*
independent_variable_f;
//用来保存前k-1个值
double*
independent_variable_b;
//用来保存后k-1个值
double value_f;
double value_b;
if (0==end)
{
return function_value[end];
}
else
{
function_value_f=new double[end];
independent_variable_f=new double[end];
function_value_b=new double[end];
independent_variable_b=new double[end];
for (int i=1;i<=end;i++)
{
function_value_f[i-1]=function_value[i];
independent_variable_f[i-1]=independent_variable[i];
}
for (int i=0;i<=end-1;i++)
{
function_value_b[i]=function_value[i];
independent_variable_b[i]=independent_variable[i];
}
value_f = average_deviation(function_value_f,
independent_variable_f, end - 1);
value_b = average_deviation(function_value_b,
independent_variable_b, end - 1);
delete[] function_value_f;
delete[] function_value_b;
delete[] independent_variable_b;
delete[] independent_variable_f;
return
(value_f-value_b)/(independent_variable[end]-independent_variable[0]);
}
}

牛顿插值法(c++)的更多相关文章
- 牛顿插值法——用Python进行数值计算
拉格朗日插值法的最大毛病就是每次引入一个新的插值节点,基函数都要发生变化,这在一些实际生产环境中是不合适的,有时候会不断的有新的测量数据加入插值节点集, 因此,通过寻找n个插值节点构造的的插值函数与n ...
- 牛顿插值法及其C++实现
h1 { margin-bottom: 0.21cm } h1.western { font-family: "Liberation Sans", sans-serif; font ...
- Matlab数值计算示例: 牛顿插值法、LU分解法、拉格朗日插值法、牛顿插值法
本文源于一次课题作业,部分自己写的,部分借用了网上的demo 牛顿迭代法(1) x=1:0.01:2; y=x.^3-x.^2+sin(x)-1; plot(x,y,'linewidth',2);gr ...
- 牛顿插值法(c++)【转载】
摘自<c++和面向对象数值计算>,代码简洁明快,采用模板函数,通用性增强,牛顿差分合理利用存储空间,采用Horner算法(又称秦九韶算法)提高精度,减少时间复杂度,高!确实是高!对其中代码 ...
- 差分形式的牛顿插值法(c++)
本程序对cosx函数进行插值,取步长为0.1,因此x的值为0.00,0.10,0.20,0.30,对应的y值为cos(0.00),cos(0.10),cos(0.20),cos(0.30),其实本程序 ...
- CPP,MATLAB实现牛顿插值
牛顿插值法的原理,在维基百科上不太全面,具体可以参考这篇文章.同样贴出,楼主作为初学者认为好理解的代码. function p=Newton1(x1,y,x2) %p为多项式估计出的插值 syms x ...
- 埃尔米特插值问题——用Python进行数值计算
当插值的要求涉及到对插值函数导数的要求时,普通插值问题就变为埃尔米特插值问题.拉格朗日插值和牛顿插值的要求较低,只需要插值函数的函数值在插值点与被插函数的值相等,以此来使得在其它非插值节点插值函数的值 ...
- 风景区的面积及道路状况分析问题 test
参考文献: https://wenku.baidu.com/view/b6aed86baf1ffc4ffe47ac92.html #include <bits/stdc++.h> us ...
- ORACLE SQL 实现IRR的计算
一.IRR计算的原理: 内部收益率(Internal Rate of Return (IRR)),就是资金流入现值总额与资金流出现值总额相等.净现值等于零时的折现率. 用公式 标识:-200+[30/ ...
随机推荐
- requirejs:模块加载(require)及定义(define)时的路径理解
给新来的实习生普及下JS基本知识,看到比较好的文章 转载https://blog.csdn.net/xuxiaoping1989/article/details/52384778 接触过require ...
- intellij IDEA github clone 指定分支代码
1.问题描述 在实际开发中,我们通常会使用idea克隆一个新项目(clone),通常情况下,我们默认克隆的是master分支,但是如果master分支只是一个空文件夹而已,真正的代码在develop分 ...
- EF 拉姆达 linq if else (整理)
首先想到: var data0 = db.T_Plants2; //这里加.AsQueryable() ) { .Where(d => d.NaturalEcosystem == true); ...
- Python学习日记(二十七) 反射和几个内置函数
isinstance() 判断isinstance(obj,cls)中obj是否是cls类的对象 class Person: def __init__(self,name): self.name = ...
- Web渗透
- Istio1.1.8部署
istio安装 整体步骤: 下载 Istio 发行版. 完成必要的 Kubernetes 平台设置 检查对 Pod 和服务的要求. 安装高于 2.10 版本的 Helm 客户端. 安装之前的下载和准备 ...
- 使用Arduino和LED光柱显示器件轻松制作电池电压指示器
电池有一定的电压限制,如果电压在充电或放电时超出规定的限制,电池的使用寿命就会受到影响或降低.每当我们使用电池供电的项目,有时我们需要检查电池电压电量,确定是否需要充电或更换.本电路将帮助您监测电池电 ...
- Windows 将FTP 映射到本地文件夹 --简化操作
转载自yutiantongbu Windows 将FTP 映射到本地文件夹 --简化操作 1.右键我的电脑,选择映射网络驱动器 2.选择"连接到可用与存储文档和图片的网站" 3.接 ...
- 使用Xpath爬虫库下载诗词名句网的史书典籍类所有文章。
# 需要的库 from lxml import etree import requests # 请求头 headers = { 'User-Agent': 'Mozilla/5.0 (Windows ...
- python爬虫中的ip代理设置
设置ip代理是爬虫必不可少的技巧: 查看本机ip地址:打开百度,输入“ip地址”,可以看到本机的IP地址: 本文使用的是goubanjia.com里面的免费ip: 使用时注意要注意传输协议是http还 ...