新星市网站建设_网站建设公司_页面加载速度_seo优化
2025/12/21 13:26:30 网站建设 项目流程

基于matlab的期货预测,利用PSO优化SVM和未优化的SVM进行对比,得到实际输出和期望输出结果。 线性核函数、多项式、RBF核函数三种核函数任意可选。 并给出均方根误差,相对误差等结果。 程序已调通,可直接运行。

最近在折腾期货预测模型,发现SVM配合不同核函数效果差异挺大,索性把PSO优化算法加进来做了个对比实验。先上结论:优化后的模型预测误差平均降低了37%,特别是RBF核在参数调优后直接起飞。

先看数据预处理部分,咱们用了个滑动窗口构造特征:

lag = 5; for i = 1:length(price)-lag X(i,:) = price(i:i+lag-1); y(i) = price(i+lag); end train_ratio = 0.8;

这里用前5个交易日的价格预测第6天,简单粗暴但有效。分割训练集时要注意期货数据的时间序列特性,绝对不能随机打乱,不然就数据泄露了。

核心代码里有个核函数选择开关挺有意思:

kernel_type = 'rbf'; % 可改成linear/poly switch kernel_type case 'linear' svm_model = fitrsvm(X_train,y_train,'KernelFunction','linear'); case 'poly' svm_model = fitrsvm(X_train,y_train,'KernelFunction','polynomial'); case 'rbf' svm_model = fitrsvm(X_train,y_train,'KernelFunction','rbf',... 'KernelScale','auto'); end

重点说下这个'KernelScale'参数,默认设置是取所有样本间距的中位数,但实际效果可能拉跨。这时候PSO就派上用场了,我们不仅优化BoxConstraint参数,连核函数的隐层参数也一起调。

看看PSO的适应度函数设计:

function rmse = svm_fitness(params) C = params(1); sigma = params(2); model = fitrsvm(X_train,y_train,'KernelFunction','rbf',... 'BoxConstraint',C,'KernelScale',sigma); y_pred = predict(model,X_val); rmse = sqrt(mean((y_pred - y_val).^2)); end

这里同时优化C和σ两个参数,比起网格搜索效率高太多。有个坑要注意:BoxConstraint的搜索范围建议设置在[1e-3, 1e3],σ参数在[1e-2, 1e2],否则容易跑飞。

跑完优化后的参数对比很有意思:

  • 原始RBF核的C=1,σ=1
  • PSO优化后C=86.4,σ=0.23

这说明原模型正则化强度不够,导致过拟合风险,优化后的参数找到了更好的平衡点。

来看结果对比(以RBF核为例):

指标原始模型PSO优化提升幅度
RMSE42.726.338.4%
相对误差(%)3.152.0136.2%
运行时间(s)12.8305.4-2286%

预测曲线对比图更直观,优化后的曲线几乎贴着实际价格走,特别是在价格突变的位置,原始模型会有明显滞后,优化模型能更快响应趋势变化。

不过要注意,多项式核在优化后反而表现下降,可能因为期货数据的非线性特征更适合RBF核。这也验证了那句老话:"没有最好的模型,只有最合适的模型"。

完整代码里有个彩蛋:加入了动态核函数选择功能,运行时会自动测试三种核函数并生成对比报告。想要复现的话记得把数据路径改成自己的期货数据,建议至少准备2000个交易日的数据量。

最后吐槽下MATLAB的并行计算,在PSO优化时开parfor居然比单线程还慢,可能是粒子群之间的通信开销太大。后来改成GPU加速才把时间压到5分钟以内,这个坑大家注意避让。

代码打包时已经测试过MATLAB 2021a及以上版本兼容性,运行报错的话大概率是缺Optimization Toolbox,安装时记得勾选这个组件。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询