python一维插值以及subplot画图范例

背景:

python实现插值以及subpot画子图范例。

代码:

import numpy as np
import matplotlib.pyplot as pl
from scipy import interpolate


lb,ub = 0,20


#10个样本点
x = np.linspace(lb,ub,10)
y = 100*np.sqrt(np.abs(np.sin(x)))+x


x_new = np.linspace(lb,ub,100)


#subplot
subplotid = np.array([221,222,212])
#插值方法
method = ['linear', 'nearest', 'zero', 'slinear', 'quadratic', 'cubic']


for value in range(0,6):
    #返回线性插值函数
    # method[value]对应的差值方法
    f_liner = interpolate.interp1d(x,y,kind = method[value])
    
    y_b = f_liner(x_new)


    '''
     subplotid[value//2]:控制相邻两个占用同一个位置
     method[value-value%2:value-value%2+2]:加标题,(子图加图例好像失败?)
     
    '''
    pl.subplot(subplotid[value//2],title = str(method[value-value%2:value-value%2+2]))


    #偶数个的时候画样本点
    if value%2==0:
        pl.plot(x,y,'ro')
        
    pl.plot(x_new,y_b,label = method[value])
     
    
pl.legend()
pl.show()

结果:



  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值