爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 7368|回复: 1

[源代码] 时间序列一维插值

[复制链接]

新浪微博达人勋

发表于 2022-9-26 11:52:35 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
1、需求缘起

一维序列插值是常用功能,我常用scipy.interpolate.interp1d来实现,
但是,这个函数对时间格式的序列用不了,
于是,我想着,把时间转为浮点型,再插值不就行了!

2、源代码

import numpy as np
from datetime import datetime,timedelta
from scipy.interpolate import interp1d

# 根据时间序列t,及其对应的值序列value,插值出时间序列t2的值序列
def time_interp1d(t,value,t2):

    # np.datetime64序列转浮点型序列:
    float_t=t.astype("float")
    float_t2=t2.astype("float")

    # 拟合函数:
    f=interp1d(float_t,value)
    value2=f(float_t2)
    return value2

if __name__=="__main__":

    import matplotlib.pyplot as plt

    t0=datetime(2022,9,7,0)
    t1=datetime(2022,9,7,12)

    # 已知的时间序列与值:
    t=np.arange(t0,t1,timedelta(minutes=37))
    value=np.random.randn( len(t) )

    # 想知道以下时间序列的值:
    t2=np.arange(t0,t1,timedelta(hours=1))

    value2=time_interp1d(t,value,t2)

    plt.plot(t,value,c='blue',label='raw data')
    plt.scatter(t2,value2,c='red',label='interp data')
    plt.legend()
    plt.show()

时间序列插值.png


time_interp1d.py

999 Bytes, 下载次数: 3, 下载积分: 金钱 -5

密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2024-3-21 15:53:46 | 显示全部楼层
除年份外,时间转换成序号1,2,3~n这样作为自变量是比较常用的做法。年份的话就以年份为自变量。
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表