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()

结果:



Python中,可以使用`matplotlib.pyplot`库的`subplot`函数来创建子图。`subplot`函数接受三个参数:行数、列数和当前子图的索引。通过指定不同的索引,可以在同一个画布上创建多个坐标轴。 下面是一个示例代码,展示了如何使用`subplot`函数绘制多个子图: ```python import matplotlib.pyplot as plt # 创建画布 plt.figure(figsize=(8, 6)) # 第一个子图 ax1 = plt.subplot(2, 2, 1) # 绘制图形 ax1.plot([1, 2, 3, 4], [1, 4, 2, 3]) # 设置标题 ax1.set_title('Subplot 1') # 第二个子图 ax2 = plt.subplot(2, 2, 2) # 绘制图形 ax2.plot([1, 2, 3, 4], [4, 2, 3, 1]) # 设置标题 ax2.set_title('Subplot 2') # 第三个子图 ax3 = plt.subplot(2, 1, 2) # 绘制图形 ax3.plot([1, 2, 3, 4], [1, 2, 3, 4]) # 设置标题 ax3.set_title('Subplot 3') # 调整子图之间的距离 plt.tight_layout() # 显示图像 plt.show() ``` 在上面的代码中,我们创建了一个2行2列的画布,然后使用`subplot`函数创建了三个子图。每个子图都是一个独立的坐标轴,可以在其中绘制不同的图形。通过设置不同的行数、列数和索引,可以自由地控制子图的布局。 希望这个例子可以帮到你!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python 使用plt画图,去除图片四周的白边方法](https://download.csdn.net/download/weixin_38731479/14869610)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Python绘图基础:认识绘图区 + subplot创建子图](https://blog.csdn.net/weixin_47269399/article/details/124289755)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Python作图总结——plot,subplots](https://blog.csdn.net/dongke1991/article/details/127168621)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值