概述
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 时序模型的使用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复