Python实现的拉格朗日插值法示例


Posted in Python onJanuary 08, 2019

本文实例讲述了Python实现的拉格朗日插值法。分享给大家供大家参考,具体如下:

拉格朗日插值简单介绍

拉格朗日插值法是以法国十八世纪数学家约瑟夫·拉格朗日命名的一种多项式插值方法。

许多实际问题中都用函数来表示某种内在联系或规律,而不少函数都只能通过实验和观测来了解。在若干个不同的地方得到相应的观测值,拉格朗日插值法可以找到一个简单函数,其恰好在各个现测的点取到观测到的值,这个函数可以是代数多项式,三角多项式等。

完整Python示例:

# -*- coding:utf-8 -*-
#拉格朗日插值代码
import pandas as pd #导入数据分析库Pandas
from scipy.interpolate import lagrange #导入拉格朗日插值函数
inputfile = 'catering_sale.xls' #销量数据路径
data = pd.read_excel(inputfile) #读入数据
data[u'销量'][(data[u'销量'] < 400) | (data[u'销量'] > 5000)] = None #过滤异常值,将其变为空值
#自定义列向量插值函数
#s为列向量,n为被插值的位置,k为取前后的数据个数,默认为5
def ployinterp_column(s, n, k=5):
 y = s[list(range(n-k, n)) + list(range(n+1, n+1+k))] #取数
 y = y[y.notnull()] #剔除空值
 return lagrange(y.index, list(y))(n) #插值并返回插值结果
#逐个元素判断是否需要插值
for i in data.columns:
 for j in range(len(data)):
  if data[i].isnull()[j]: #如果为空即插值。
   data[i][j] = ployinterp_column(data[i], j)
print(data)

运行结果:

            日期           销量
0   2015-03-01  -291.400000
1   2015-02-28  2618.200000
2   2015-02-27  2608.400000
3   2015-02-26  2651.900000
4   2015-02-25  3442.100000
5   2015-02-24  3393.100000
6   2015-02-23  3136.600000
7   2015-02-22  3744.100000
8   2015-02-21  4275.254762
9   2015-02-20  4060.300000
10  2015-02-19  3614.700000
11  2015-02-18  3295.500000
12  2015-02-16  2332.100000
13  2015-02-15  2699.300000
14  2015-02-14  4156.860423
15  2015-02-13  3036.800000
16  2015-02-12   865.000000
17  2015-02-11  3014.300000
18  2015-02-10  2742.800000
19  2015-02-09  2173.500000
20  2015-02-08  3161.800000
21  2015-02-07  3023.800000
22  2015-02-06  2998.100000
23  2015-02-05  2805.900000
24  2015-02-04  2383.400000
25  2015-02-03  2620.200000
26  2015-02-02  2600.000000
27  2015-02-01  2358.600000
28  2015-01-31  2682.200000
29  2015-01-30  2766.800000
..         ...          ...
171 2014-08-31  3494.700000
172 2014-08-30  3691.900000
173 2014-08-29  2929.500000
174 2014-08-28  2760.600000
175 2014-08-27  2593.700000
176 2014-08-26  2884.400000
177 2014-08-25  2591.300000
178 2014-08-24  3022.600000
179 2014-08-23  3052.100000
180 2014-08-22  2789.200000
181 2014-08-21  2909.800000
182 2014-08-20  2326.800000
183 2014-08-19  2453.100000
184 2014-08-18  2351.200000
185 2014-08-17  3279.100000
186 2014-08-16  3381.900000
187 2014-08-15  2988.100000
188 2014-08-14  2577.700000
189 2014-08-13  2332.300000
190 2014-08-12  2518.600000
191 2014-08-11  2697.500000
192 2014-08-10  3244.700000
193 2014-08-09  3346.700000
194 2014-08-08  2900.600000
195 2014-08-07  2759.100000
196 2014-08-06  2915.800000
197 2014-08-05  2618.100000
198 2014-08-04  2993.000000
199 2014-08-03  3436.400000
200 2014-08-02  2261.700000

[201 rows x 2 columns]

附:catering_sale.xls点击此处本站下载

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python中join和split用法实例
Apr 14 Python
python距离测量的方法
Mar 06 Python
Python中的函数作用域
May 07 Python
python 利用栈和队列模拟递归的过程
May 29 Python
python机器人运动范围问题的解答
Apr 29 Python
python内存动态分配过程详解
Jul 15 Python
Python3+selenium实现cookie免密登录的示例代码
Mar 18 Python
django的模型类管理器——数据库操作的封装详解
Apr 01 Python
Python绘图之二维图与三维图详解
Aug 04 Python
Pycharm连接gitlab实现过程图解
Sep 01 Python
jupyter notebook保存文件默认路径更改方法汇总(亲测可以)
Jun 09 Python
Python实现信息管理系统
Jun 05 Python
Python3 安装PyQt5及exe打包图文教程
Jan 08 #Python
在python3中pyqt5和mayavi不兼容问题的解决方法
Jan 08 #Python
Django之模型层多表操作的实现
Jan 08 #Python
对python mayavi三维绘图的实现详解
Jan 08 #Python
利用python和ffmpeg 批量将其他图片转换为.yuv格式的方法
Jan 08 #Python
python+opencv打开摄像头,保存视频、拍照功能的实现方法
Jan 08 #Python
Python OpenCV对本地视频文件进行分帧保存的实例
Jan 08 #Python
You might like
ThinkPHP查询返回简单字段数组的方法
2014/08/25 PHP
浅析php工厂模式
2014/11/25 PHP
PHP处理bmp格式图片的方法分析
2017/07/04 PHP
IE JS编程需注意的内存释放问题
2009/06/23 Javascript
jQuery实现数字加减效果汇总
2014/12/16 Javascript
Jquery网页内滑动缓冲导航的实现代码
2015/04/05 Javascript
学习JavaScript设计模式(接口)
2015/11/26 Javascript
JS获取月份最后天数、最大天数与某日周数的方法
2015/12/08 Javascript
精彩的Bootstrap案例分享 重点在注释!(选项卡、栅格布局)
2016/07/01 Javascript
详解如何使用Vue2做服务端渲染
2017/03/29 Javascript
JavaScript创建对象方式总结【工厂模式、构造函数模式、原型模式等】
2018/12/19 Javascript
Vue 组件参数校验与非props特性的方法
2019/02/12 Javascript
浅析vue-cli3配置webpack-bundle-analyzer插件【推荐】
2019/10/23 Javascript
一文秒懂nodejs中的异步编程
2021/01/28 NodeJs
[52:27]2018DOTA2亚洲邀请赛 3.31 小组赛B组 paiN vs Secret
2018/04/01 DOTA
[46:53]Secret vs Liquid 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
python:pandas合并csv文件的方法(图书数据集成)
2018/04/12 Python
python获取微信企业号打卡数据并生成windows计划任务
2019/04/30 Python
Django中reverse反转并且传递参数的方法
2019/08/06 Python
通过字符串导入 Python 模块的方法详解
2019/10/27 Python
Python实现密码薄文件读写操作
2019/12/16 Python
CSS3 实现的缩略图悬停效果
2020/12/09 HTML / CSS
Mountain Warehouse澳大利亚官网:欧洲家庭户外品牌倡导者
2016/11/20 全球购物
英国时尚服饰电商:Boohoo
2017/10/12 全球购物
全球精选男装和家居用品:Article
2020/04/13 全球购物
WSDL的操作类型主要有几种
2013/07/19 面试题
入团者的自我评价分享
2013/12/02 职场文书
小学校园广播稿集锦
2014/10/04 职场文书
暑期社会实践个人总结
2015/03/06 职场文书
证券公司客户经理岗位职责
2015/04/09 职场文书
2015年学校安全工作总结
2015/04/22 职场文书
小学生安全教育主题班会
2015/08/12 职场文书
python实现腾讯滑块验证码识别
2021/04/27 Python
mysql脏页是什么
2021/07/26 MySQL
美元符号 $
2022/02/17 杂记
Redis中key的过期删除策略和内存淘汰机制
2022/04/12 Redis