我是靠谱客的博主 整齐铅笔,最近开发中收集的这篇文章主要介绍fbprophet 时序模型的使用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Facebook 开源了一个时间序列预测的算法,叫做 fbprophet, prophet 算法不仅可以处理时间序列存在一些异常值的情况,也可以处理部分缺失值的情形,还能够全自动地预测时间序列未来的走势。

1.安装,安装这里就不说了,随说安装痛苦但是 Anaconda 下面直接安装就可以。

2.安装完成后的使用。

import pandas as pd
from fbprophet import Prophet
from matplotlib import pyplot
df=pd.read_csv("../fbprophet/20210713.csv")
print(df)

df =df.loc[:,['reportTime','Ratio']]
df.columns = ['ds','y']
df['ds']=pd.to_datetime(df['ds'])
print(df)
'''
#实例化一个新Prophet对象来拟合模型
#easonality_mode='multiplicative'参数来建模乘法季节性
# additive 
#任何添加的季节性或额外的回归量将默认使用seasonality_mode设置的内容,
#但可以通过指定mode='additive'或mode='multiplicative'作为参数来覆盖seasonality_mode设置的内容。
 Python
m = Prophet(seasonality_mode='multiplicative')
m.add_seasonality('quarterly', period=91.25, fourier_order=8, mode='additive')
m.add_regressor('regressor', mode='additive')

Prophet 可使用 logistic 增长 趋势模型进行预测
growth='logistic' Prophet(growth='logistic')
growth="linear"
piecewise_logistic
分段线性函数(linear) 和逻辑回归函数(logistic)
而m=Prophet() 默认使用分段线性函数(linear),并且如果要使用
逻辑回归函数是需要设置capacity 的值
'''
m = Prophet(growth='logistic')
#growth='logistic'  时 piecewise_logistic 需要cap
df['cap']=5
m.fit(df)

#预测
#D代表天,M代表月 freq='W' 周 periods =365 代表后续365天 
#H代表小时 periods为预测数据小时 可以为 24/48 72 小时的数据

#支持小时 分钟秒预测
#支持分钟T或min 10min分钟  5min 那么 periods 指的时预测多少个10分钟的数据
#支持S 预测
future=m.make_future_dataframe(freq='D',periods=10)
print(future.tail())
#growth='logistic'  时 piecewise_logistic 需要cap 
future['cap'] = 5
forecast=m.predict(future)

print(forecast[['ds', 'yhat', 'yhat_lower', 'yhat_upper']].tail())

#展示预测结果趋势图和真实值
fig_show=m.plot(forecast)
pyplot.show()

最后

以上就是整齐铅笔为你收集整理的fbprophet 时序模型的使用的全部内容,希望文章能够帮你解决fbprophet 时序模型的使用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(57)

评论列表共有 0 条评论

立即
投稿
返回
顶部