在算法分析过程中,我们经常会遇到数据需要处理插值的过程,为了方便理解,我们这里给出相关概念和源程序,希望能帮助到您!

案例一:

已知坐标 (x0, y0) 与 (x1, y1),要求得区间 [x0, x1] 内某一点位置 x 在直线上的y值。两点间直线方程,我们有

那么,如何实现它呢?

依据数值分析,我们可以发现存在递归情况

import matplotlib.pyplot as plt

"""

详细描述;

1)计算n阶差商 f[x0, x1, x2 ... xn]

2) xi 所有插值节点的横坐标集合 o

3) fi 所有插值节点的纵坐标集合 / \

4) 返回xi的i阶差商(i为xi长度减1) o o

5) a. 必须确保xi与fi长度相等 / \ / \

b. 由于用到了递归,所以留意不要爆栈了. o o o o

c. 递归减递归(每层递归包含两个递归函数), 每层递归次数呈二次幂增长,总次数是一个满二叉树的所有节点数量(所以极易栈溢出)

"""

def get_order_diff_quot(xi = [], fi = []):

if len(xi) > 2 and len(fi) > 2:

return (get_order_diff_quot(xi[:len(xi) - 1], fi[:len(fi) - 1]) - get_order_diff_quot(xi[1:len(xi)], fi[1:len(fi)])) / float(xi[0] - xi[-1])

return (fi[0] - fi[1]) / float(xi[0] - xi[1])

"""

6) 获得Wi(x)函数;

Wi的含义举例 W1 = (x - x0); W2 = (x - x0)(x - x1); W3 = (x - x0)(x - x1)(x - x2)

7) i i阶(i次多项式)

8) xi 所有插值节点的横坐标集合

9) 返回Wi(x)函数

"""

def get_Wi(i = 0, xi = []):

def Wi(x):

result = 1.0

for each in range(i):

result *= (x - xi[each])

return result

return Wi

"""

获得牛顿插值函数

"""

def get_Newton_inter(xi = [], fi = []):

def Newton_inter(x):

result = fi[0]

for i in range(2, len(xi)):

result += (get_order_diff_quot(xi[:i], fi[:i]) * get_Wi(i-1, xi)(x))

return result

return Newton_inter

"""

demo:

"""

if __name__ == '__main__':

''' 插值节点, 这里用二次函数生成插值节点,每两个节点x轴距离位10 '''

sr_x = [i for i in range(-50, 51, 10)]

sr_fx = [i**2 for i in sr_x]

Nx = get_Newton_inter(sr_x, sr_fx) # 获得插值函数

tmp_x = [i for i in range(-50, 51)] # 测试用例

tmp_y = [Nx(i) for i in tmp_x] # 根据插值函数获得测试用例的纵坐标

''' 画图 '''

plt.figure("I love china")

ax1 = plt.subplot(111)

plt.sca(ax1)

plt.plot(sr_x, sr_fx, linestyle = '', marker='o', color='b')

plt.plot(tmp_x, tmp_y, linestyle = '--', color='r')

plt.show()

执行结果;

image.png

此外,我们也可以对一维线性插值使用指定得库:numpy.interp

numpy.interp(x,xp,fp,left = None,right = None,period = None )

将一维分段线性插值返回给具有给定离散数据点(xp,fp)的函数,该函数在x处求值

参数说明:

x : 类似数组

评估插值的x坐标

xp : 一维浮点数序列

如果未指定参数周期,则数据点的x坐标必须增加 . 否则,在用归一化周期边界之后对xp进行内部排序,xp = xp % period.

fp : 一维浮点数或复数序列

数据点的y坐标,与xp的长度相同。

left : 对应于fp的可选float或complex

x

right : 对应于fp的可选float或complex

x> xp [-1]的返回值,默认值为fp [-1]。

period : 无或浮动,可选

X坐标的句点,此参数允许对x坐标进行适当的插值。 如果指定了period,则忽略参数left和right。

Returns:

y : 浮点型或复数(对应于fp)或ndarray

内插值,形状与x相同。

Raises:

ValueError

If xp and fp have different length If xp or fp are not 1-D sequences If period == 0

检查: 如果xp没有增加,则结果是无意义的。

案例二:

另一方面:线性插值是一种使用线性多项式进行曲线拟合的方法,可以在一组离散的已知数据点范围内构造新的数据点。

实际上,这可能意味着您可以推断已知位置点之间的新的估计位置点,以创建更高频率的数据或填写缺失值。

以最简单的形式,可视化以下图像:

image.png

在此,已知数据点在位置(1,1)和(3,3)处为红色。使用线性迭代,我们可以在它们之间添加一个点,该点可以显示为蓝色。

这是一个非常简单的问题,如果我们拥有更多已知的数据点,并且想要特定频率的插值点又该怎么办呢?

这可以使用numpy包中的两个函数在Python中非常简单地实现:

#Let's create ten x and y values that follow a sine curve

import numpy as np

import matplotlib.pyplot as plt

x = np.linspace(0, 2*np.pi, 10)

y = np.sin(x)

plt.plot(x, y, 'o')

plt.show()

image

我们有十个已知点,但是假设我们要一个50个序列。

我们可以使用np.linspace做到这一点;序列的起点,序列的终点以及我们想要的数据点总数

起点和终点将与您的初始x值的起点和终点相同,因此在此我们指定0和2 * pi。我们还指定了对序列中50个数据点的请求

xvals = np.linspace(0,2 * np.pi,50)

现在,进行线性插值!使用np.interp,我们传递所需数据点的列表(我们在上面创建的50个),然后传递原始的x和y值

yinterp = np.interp(xvals,x,y)

现在,让我们绘制原始值,然后覆盖新的内插值!

plt.plot(x,y,'o')

plt.plot(xvals,yinterp,'-x')

plt.show()

image.png

案例三:

您还可以将此逻辑应用于时间序列中的x和y坐标。在这里,您将根据时间对x值进行插值,然后针对时间对y值进行插值。如果您想在时间序列中使用更频繁的数据点(例如,您想在视频帧上叠加一些数据),或者缺少数据点或时间戳不一致,这将特别有用。

让我们为一个场景创建一些数据,在该场景中,在60秒的比赛时间里,一辆赛车仅发出十个位置(x&y)输出(在整个60秒的时间内,时间也不一致):

import numpy as np

import matplotlib.pyplot as plt

timestamp = (0,5,10,15,30,35,40,50,55,60)

x_coords = (0,10,12,13,19,13,12,19,21,25)

y_coords = (0,5,10,7,2,8,15,19,14,15)

#Now, let's create the start time for the race, the end time, and the duration - we'll need these values for the linear interpolation

start_timestamp = min(timestamp)

end_timestamp = max(timestamp)

duration_seconds = (end_timestamp - start_timestamp)

#Apply the spacing, and the the interpolation independently for the x values and the y values

new_intervals = np.linspace(start_timestamp, end_timestamp, duration_seconds)

new_x_coords = np.interp(new_intervals, timestamp, x_coords)

new_y_coords = np.interp(new_intervals, timestamp, y_coords)

#Let's have a look at the interpolated positional values that we now have:

plt.plot(x_coords, y_coords, 'o')

plt.plot(new_x_coords, new_y_coords, '-x')

plt.show()

image.png

python 线性插值处理_详解Python实现线性插值法相关推荐

  1. python归一化处理_详解python实现数据归一化处理的方式:(0,1)标准化

    在机器学习过程中,对数据的处理过程中,常常需要对数据进行归一化处理,下面介绍(0, 1)标准化的方式,简单的说,其功能就是将预处理的数据的数值范围按一定关系"压缩"到(0,1)的范 ...

  2. python列表拆包_详解python 拆包可迭代数据如tuple, list

    详解python 拆包可迭代数据如tuple, list 拆包是指将一个结构中的数据拆分为多个单独变量中. 以元组为例: >>> a = ('windows', 10, 25.1, ...

  3. python操作目录_详解python中的文件与目录操作

    详解python中的文件与目录操作 一 获得当前路径 1.代码1 >>>import os >>>print('Current directory is ',os. ...

  4. python模式匹配算法_详解Python 最短匹配模式

    问题 你正在试着用正则表达式匹配某个文本模式,但是它找到的是模式的最长可能匹配. 而你想修改它变成查找最短的可能匹配. 解决方案 这个问题一般出现在需要匹配一对分隔符之间的文本的时候(比如引号包含的字 ...

  5. python opencv 直方图均衡_详解python OpenCV学习笔记之直方图均衡化

    本文介绍了python OpenCV学习笔记之直方图均衡化,分享给大家,具体如下: 官方文档 – https://docs.opencv.org/3.4.0/d5/daf/tutorial_py_hi ...

  6. python xlrd安装_详解python中xlrd包的安装与处理Excel表格

    一.安装xlrd 地址 下载后,使用 pip install .whl安装即好. 查看帮助: >>> import xlrd >>> help(xlrd) Help ...

  7. python制作界面_详解python做UI界面的方法

    详解python做UI界面的方法 更新时间:2019年02月27日 14:44:34 投稿:laozhang 在本文里我们给大家整理了关于python做UI界面的方法和具体步骤,对此有需要的朋友们可以 ...

  8. python namedtuple用法_详解Python中namedtuple的使用

    namedtuple是Python中存储数据类型,比较常见的数据类型还有有list和tuple数据类型.相比于list,tuple中的元素不可修改,在映射中可以当键使用. namedtuple: na ...

  9. python gil 解除_详解Python中的GIL(全局解释器锁)详解及解决GIL的几种方案

    先看一道GIL面试题: 描述Python GIL的概念, 以及它对python多线程的影响?编写一个多线程抓取网页的程序,并阐明多线程抓取程序是否可比单线程性能有提升,并解释原因. GIL:又叫全局解 ...

  10. python udp编程_详解python UDP 编程

    前面我们讲了 TCP 编程,我们知道 TCP 可以建立可靠连接,并且通信双方都可以以流的形式发送数据.本文我们再来介绍另一个常用的协议–UDP.相对TCP,UDP则是面向无连接的协议. UDP 协议 ...

最新文章

  1. 受益匪浅:十个哲理寓言,十个成功秘诀
  2. Wex5铛铛开发环境搭建步骤
  3. 树莓派wifi环境下初始化及环境配置
  4. 信息传递服务器,AJAX的与服务器之间的信息传递原理(初学)
  5. 因为银行原因出现房贷逾期,怎么修复征信?
  6. Android中弹出对话框,AlertDialog关键代码
  7. 设置Tomcat管理员用户名和密码
  8. 一场关于Google不作恶信条的辩论会
  9. python36怎么安装_centos 安装 python36
  10. linux界面更改用户名,linux跳过用户名密码登陆界面方法
  11. Tomcat的下载及环境变量配置
  12. Docker: connection reset by peer
  13. Atitit.sql where条件表达式的原理  attilax概括
  14. 在华为服务器 RH 2288H V2上装 windows 2008
  15. java日志脱敏_java 日志脱敏框架 sensitive,优雅的打印脱敏日志
  16. 优优自走棋2.1.1
  17. [办公软件] Word文档和Excel文档的桌面图标有把锁怎么解决?
  18. Xmind 2022 Mac思维导图软件
  19. 搭建Genero BDL环境-安装篇
  20. 八代及以上笔记本发热降频的一般处理办法

热门文章

  1. 树莓派yocto构建
  2. 《结对-四则运算出题器-测试过程》
  3. 如何将flac文件转换为mp3文件?
  4. 【清华大学】深入理解操作系统(陈渝) 第一章
  5. od 查找特征码和特征码模糊搜索教程
  6. RMS数据采集分布式架构
  7. wrk 服务器性能HTTP压测工具
  8. 二行代码解决全部网页木马(含iframe/script木马)
  9. 三角函数诱导公式一:奇变偶不变,符号看象限
  10. 信息系统项目管理师下午论文的一些心得