当前位置: 首页 > wzjs >正文

网站关键词排名不稳定wordpress install.php 500

网站关键词排名不稳定,wordpress install.php 500,品牌推广软文200字,国土分局网站建设方案DAY 59 经典时序预测模型3 知识点回顾: SARIMA模型的参数和用法:SARIMA(p, d, q)(P, D, Q)m模型结果的检验可视化(昨天说的是摘要表怎么看,今天是对这个内容可视化)多变量数据的理解:内生变量和外部变量多变…

DAY 59 经典时序预测模型3

知识点回顾:

  1. SARIMA模型的参数和用法:SARIMA(p, d, q)(P, D, Q)m
  2. 模型结果的检验可视化(昨天说的是摘要表怎么看,今天是对这个内容可视化)
  3. 多变量数据的理解:内生变量和外部变量
  4. 多变量模型
    1. 统计模型:SARIMA(单向因果)、VAR(考虑双向依赖)
    2. 机器学习模型:通过滑动窗口实现,往往需要借助arima等作为特征提取器来捕捉线性部分(趋势、季节性),再利用自己的优势捕捉非线性的残差
    3. 深度学习模型:独特的设计天然为时序数据而生

作业:由于篇幅问题,无法实战SARIMAX了,可以自己借助AI尝试尝试,相信大家已经有这个能力了。

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
from statsmodels.tsa.stattools import adfuller
from statsmodels.graphics.tsaplots import plot_acf, plot_pacf
from statsmodels.tsa.statespace.sarimax import SARIMAX
import warnings
import itertools
warnings.filterwarnings('ignore')
# 显示中文
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False# 1. 加载数据
url = 'https://raw.githubusercontent.com/jbrownlee/Datasets/master/airline-passengers.csv'
df = pd.read_csv(url, header=0, index_col=0, parse_dates=True)
df.columns = ['Passengers']# 2. 划分训练集和测试集(保留最后12个月作为测试)
train_data = df.iloc[:-12]
test_data = df.iloc[-12:]print("--- 训练集 ---")
print(train_data.tail()) # 观察训练集最后5行
print("\n--- 测试集 ---")
print(test_data.head()) # 观察测试集前5行
# 3. 可视化原始数据
plt.figure(figsize=(12, 6))
plt.plot(train_data['Passengers'], label='训练集')
plt.plot(test_data['Passengers'], label='测试集', color='orange')
plt.title('国际航空乘客数量 (1949-1960)')
plt.xlabel('年份')
plt.ylabel('乘客数量 (千人)')
plt.legend()
plt.show()

# 进行季节性差分 (D=1, m=12)
seasonal_diff = df['Passengers'].diff(12).dropna()
# 再进行普通差分 (d=1)
seasonal_and_regular_diff = seasonal_diff.diff(1).dropna()# 绘制差分后的数据
plt.figure(figsize=(12, 6))
plt.plot(seasonal_and_regular_diff)
plt.title('经过一次季节性差分和一次普通差分后的数据')
plt.show()# ADF检验
result = adfuller(seasonal_and_regular_diff)
print(f'ADF Statistic: {result[0]}')
print(f'p-value: {result[1]}') # p-value越小,越说明数据平稳

 

# 绘制ACF和PACF图
fig, (ax1, ax2) = plt.subplots(2, 1, figsize=(12, 8))
plot_acf(seasonal_and_regular_diff, lags=36, ax=ax1) # 绘制36个时间点
plot_pacf(seasonal_and_regular_diff, lags=36, ax=ax2)
plt.show()

 

手动的超参数搜索:

# 固定已知参数
d = 1           # 非季节性差分阶数
D = 1           # 季节性差分阶数
m = 12          # 季节性周期(月度数据为12)# 定义待搜索的参数范围
p = q = range(0, 3)  # 非季节性参数 p和q取0-2
P = Q = range(0, 2)  # 季节性参数 P和Q取0-1# 生成所有可能的参数组合
pdq = list(itertools.product(p, [d], q))  # d固定为1
seasonal_pdq = [(x[0], D, x[2], m) for x in list(itertools.product(P, [D], Q))]  # D固定为1# 修正列名引用(假设数据列名为'Passengers')
train_column = 'Passengers'  # 请根据实际数据列名调整# 初始化最佳参数和最小AIC
best_aic = float('inf')
best_pdq = None
best_seasonal_pdq = None
best_model = Noneprint("开始网格搜索最佳SARIMA参数...")# 网格搜索最佳参数
for param in pdq:for param_seasonal in seasonal_pdq:try:# 拟合SARIMA模型model = SARIMAX(train_data[train_column],order=param,seasonal_order=param_seasonal,enforce_stationarity=False,  # 放宽平稳性约束enforce_invertibility=False, # 放宽可逆性约束disp=False)# 使用优化的拟合方法results = model.fit(method='bfgs',  # 使用BFGS优化算法maxiter=200,    # 增加最大迭代次数disp=False)# 打印当前参数组合及AICprint(f'SARIMA{param}x{param_seasonal} - AIC: {results.aic:.2f}')# 更新最佳参数if results.aic < best_aic:best_aic = results.aicbest_pdq = parambest_seasonal_pdq = param_seasonalbest_model = resultsexcept Exception as e:print(f'SARIMA{param}x{param_seasonal} 拟合失败: {str(e)}')continue
# 输出最佳模型
if best_pdq:print(f"\n最佳模型: SARIMA{best_pdq}x{best_seasonal_pdq} - AIC: {best_aic:.2f}")final_model = SARIMAX(train_data[train_column],order=best_pdq,seasonal_order=best_seasonal_pdq,enforce_stationarity=False,enforce_invertibility=False)final_results = final_model.fit(disp=False)

 

# 检查是否找到有效模型
if best_model is not None:print(f'\n最佳模型: SARIMA{best_pdq}x{best_seasonal_pdq} - AIC: {best_aic:.2f}')# 打印最佳模型摘要print(best_model.summary())# 绘制模型诊断图best_model.plot_diagnostics(figsize=(15, 10))plt.tight_layout()plt.show()else:print("\n未能找到合适的SARIMA模型。请检查:")print("1. 数据列名是否正确(当前使用:", train_column, ")")print("2. 数据是否包含缺失值或异常值")print("3. 尝试进一步调整参数范围")print("4. 考虑使用其他时间序列模型")

 

# 1. 预测测试集
forecast = final_results.get_forecast(steps=len(test_data))
forecast_mean = forecast.predicted_mean
forecast_ci = forecast.conf_int()# 2. 评估模型
from sklearn.metrics import mean_squared_error
import numpy as npmse = mean_squared_error(test_data[train_column], forecast_mean)
rmse = np.sqrt(mse)
print(f'测试集 MSE: {mse:.2f}')
print(f'测试集 RMSE: {rmse:.2f}')# 3. 绘制预测结果
plt.figure(figsize=(12, 6))
plt.plot(train_data.index, train_data[train_column], label='训练数据')
plt.plot(test_data.index, test_data[train_column], label='真实值', color='orange')
plt.plot(test_data.index, forecast_mean, label='预测值', color='red')
plt.fill_between(forecast_ci.index,forecast_ci.iloc[:, 0],forecast_ci.iloc[:, 1],color='pink', alpha=0.5, label='95%置信区间')
plt.title('SARIMA模型预测 vs. 真实值')
plt.xlabel('日期')
plt.ylabel('乘客数量 (千人)')
plt.legend()
plt.grid(True, alpha=0.3)
plt.show()

 

@浙大疏锦行 

http://www.dtcms.com/wzjs/616317.html

相关文章:

  • php做的网站收录百度官网首页官网
  • 广东手机网站建设哪家专业搜索引擎有哪些?
  • 推广网站怎么做能增加咨询做一个响应式网站价格
  • 做牛仔裤的小视频网站网站推广和精准seo
  • 网站建设系统改版wordpress 当前页面登录密码
  • 单页面网站制作教程做网站端口无法清除
  • 网站怎么制作视频教程做网站阿里云买哪个服务器好点
  • 网站静态和动态区别是什么华联股份股票
  • 邯郸做网站多少钱网站怎么做的支付宝
  • 网站制作的步骤男女做羞羞羞的事视频网站
  • 公司网站升级改版方案竞价移动网站
  • 那些网站反爬做的好电子商务平台定制开发
  • 专业做网站公司杯子网站开发方案模板
  • 和动物做的网站wordpress mip手机主题
  • 网站跳转微信链接线下推广小组所述的推广方案是针对哪两个团体
  • 企业整站网站模板下载wordpress vue 关系
  • 合肥环保公司网站建设品牌网球拍有哪些
  • 惠州品牌网站建设价格全国新农村建设网站
  • 如何做游戏渠道网站北京做seo的公司
  • 网站建设初学网站建设技术经费预算
  • 北京亦庄做网站公司盘多多网盘资源库
  • 网站主题有哪些内容app外包推广
  • c 网站开发需要什么网站建设定制开发服务
  • 广州贸易网站网页视频怎么下载到本地视频手机
  • 济南软月建站网站建设_微信开发
  • 网站设计目标与背景wordpress服务器选择
  • 智慧农业网站建设静态html转化wordpress主题
  • 歌手投票网站怎么做中国前500强企业名单
  • 做公司网站建设价格网站制作实例教程
  • 响应式学校网站模板广告公司加盟