时间序列预测的特征工程技术

Ray

时间序列预测的特征工程技术

时间序列预测是数据科学中一个重要且具有挑战性的领域。为了提高预测模型的性能,特征工程在其中起着至关重要的作用。本文将介绍几种常用且强大的时间序列特征工程技术,帮助数据科学家更好地处理时间序列数据并提高预测准确性。

1. 滞后特征

滞后特征是时间序列预测中最基本也最重要的特征之一。它基于这样一个假设:过去的值对未来的值有影响。通过创建滞后特征,我们可以捕捉到时间序列的自相关性。

def create_lag_features(df, lag_list):
    for lag in lag_list:
        df[f'lag_{lag}'] = df['target'].shift(lag)
    return df

# 示例使用
df = create_lag_features(df, [1, 7, 30])

2. 滑动窗口特征

滑动窗口特征可以捕捉时间序列在不同时间尺度上的行为。常见的滑动窗口统计量包括均值、标准差、最大值和最小值等。

def create_rolling_features(df, window_list):
    for window in window_list:
        df[f'rolling_mean_{window}'] = df['target'].rolling(window).mean()
        df[f'rolling_std_{window}'] = df['target'].rolling(window).std()
    return df

# 示例使用
df = create_rolling_features(df, [7, 30, 90])

3. 趋势特征

趋势特征用于捕捉时间序列的长期变化趋势。可以使用简单的时间索引或更复杂的多项式特征来建模非线性趋势。

import numpy as np

def create_trend_features(df):
    df['linear_trend'] = np.arange(len(df))
    df['quadratic_trend'] = df['linear_trend'] ** 2
    df['cubic_trend'] = df['linear_trend'] ** 3
    return df

df = create_trend_features(df)

4. 季节性特征

季节性特征用于捕捉时间序列中的周期性模式。可以使用傅里叶项或者季节性哑变量来表示季节性。

import numpy as np

def create_fourier_features(df, freq, order):
    for n in range(1, order + 1):
        df[f'sin_{freq}_{n}'] = np.sin(2 * n * np.pi * df.index.dayofyear / freq)
        df[f'cos_{freq}_{n}'] = np.cos(2 * n * np.pi * df.index.dayofyear / freq)
    return df

# 示例使用:创建年度季节性特征
df = create_fourier_features(df, freq=365.25, order=3)

5. 日期时间特征

从日期时间中提取的特征可以帮助模型捕捉与时间相关的模式。

def create_datetime_features(df):
    df['hour'] = df.index.hour
    df['day_of_week'] = df.index.dayofweek
    df['quarter'] = df.index.quarter
    df['month'] = df.index.month
    df['year'] = df.index.year
    df['day_of_year'] = df.index.dayofyear
    df['week_of_year'] = df.index.isocalendar().week
    return df
df = create_datetime_features(df)

6. 外部特征

在许多实际应用中,外部因素对时间序列有重要影响。例如,在销售预测中,促销活动、假期等都可能是重要的外部特征。

def add_holiday_features(df, country='US'):
    from pandas.tseries.holiday import USFederalHolidayCalendar
    cal = USFederalHolidayCalendar()
    holidays = cal.holidays(start=df.index.min(), end=df.index.max())
    df['is_holiday'] = df.index.isin(holidays).astype(int)
    return df
df = add_holiday_features(df)

在实际应用中,这些特征工程技术通常需要结合使用,并根据具体问题进行调整。此外,使用特征选择方法来识别最相关的特征也是很重要的,因为并非所有生成的特征都对预测有帮助。

时间序列分解示例

通过合理运用这些特征工程技术,我们可以显著提高时间序列预测模型的性能。然而,需要注意的是,特征工程是一个迭代的过程,需要不断尝试和优化。同时,还要考虑模型的可解释性和计算效率,在特征的数量和质量之间找到平衡。

最后,随着深度学习技术在时间序列预测中的应用,如LSTM和Transformer模型,部分特征工程工作可能会被模型自动学习。但是,对于大多数实际应用场景,良好的特征工程仍然是提高预测准确性的关键因素。

avatar
0
0
0
相关项目
Project Cover

pytorch-forecasting

PyTorch Forecasting 是一个基于 PyTorch 的时间序列预测包,适用于实际应用和研究。它支持多种神经网络架构及自动日志记录,利用 PyTorch Lightning 实现多 GPU/CPU 的扩展训练,并内置模型解释功能。关键特性包括时间序列数据集类、基本模型类、增强的神经网络架构、多视角时间序列指标和超参数优化。安装简便,支持 pip 和 conda,文档详尽,并包含模型比较和使用案例。

Project Cover

neural_prophet

NeuralProphet是一个基于PyTorch的开源框架,将神经网络与传统时间序列算法结合,专为时间序列预测而设计。它提供简便的代码接口,支持模型定制、趋势检测、季节性分析和事件影响评估,适合高频次和长期数据。项目仍在beta阶段,欢迎社区贡献。

Project Cover

gluonts

GluonTS是一个基于Python的时间序列建模库,专注于采用深度学习方法进行概率预测。支持多种深度学习框架,包括PyTorch和MXNet,提供易于安装和使用的特性。适用于多种应用场景,如商业分析和数据科学。由一个积极的开源社区维护和发展。

Project Cover

iTransformer

iTransformer是一种用于多变量时间序列预测的开源模型,无需修改任何Transformer模块。它在处理大规模数据时表现出色,具备显著的性能提升和强大的泛化能力。iTransformer已在多种基准测试中表现优异,支持静态协变量和概率发射头。用户可通过pip安装,并使用项目提供的详细训练和评估脚本。更多信息请参阅官方论文。

Project Cover

flow-forecast

Flow Forecast 是一个开源时间序列预测深度学习框架,提供最新的Transformer、注意力模型、GRU等技术,并具有易于理解的解释指标、云集成和模型服务功能。该框架是首个支持Transformer模型的时间序列框架,适用于流量预测、分类和异常检测。

Project Cover

Time-LLM

Time-LLM将大型语言模型重新用于时序预测,利用其强大功能处理时序数据,并结合专家知识和任务说明提升预测精度。支持Llama-7B、GPT-2和BERT等模型,框架灵活且适应性广泛。了解Time-LLM的最新更新、使用案例和技术细节,访问我们的详细介绍及相关资源。

Project Cover

orbit

Orbit 是一个用于贝叶斯时间序列预测和推断的 Python 包,提供直观的初始化-拟合-预测接口。支持的模型包括ETS、LGT、DLT和KTR,采用MCMC、MAP和VI等方法进行优化。用户可以通过PyPI、源码或Anaconda安装,并提供详细的文档和教程。

Project Cover

LTSF-Linear

LTSF-Linear是一个高效的线性模型家族,包括Linear、NLinear和DLinear,专为时间序列预测设计。该模型支持单变量和多变量长时间预测,具有高效率、可解释性和易用性,显著优于Transformer模型。

Project Cover

Informer2020

Informer引入ProbSparse注意机制,大幅提升长序列时间序列预测的效率和精度。该模型利用概率分布选择活跃查询,避免冗余计算,适用于多种数据集,并在AIJ和AAAI'21获奖。提供详细的实验设置、Colab示例和数据下载链接,帮助用户快速上手并复现结果。

最新项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号