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

时间序列预测--基于CNN的股价预测(Matlab代码实现)

       目录

💥1 概述

📚2 运行结果

🎉3 参考文献

👨‍💻4 Matlab代码


💥1 概述

时间序列预测有很多方法,如传统的时序建模方法ARIMA、周期因子法、深度学习网络等,本次实验采用最简单的卷积神经网络进行训练。对于用CNN处理时序数据,通常使用一维卷积网络Conv1d。

随着我国资本市场的快速发展和居民收入水平的逐步提升,股票市场吸引了越来越多的投资者参与其中,特别是在2020年新冠疫情影响下,为提振经济实行的较为宽松的货币政策令股票市场表现不俗,股市吸引了大量新增投资者。数据显示,截至2020年12月,中国A股投资者共计1.77亿户,户均市值达到45万,全年新增投资者1802.11万户,同比增加了36.02%。股市的参与人数众多说明市场交易活跃,但是,个人投资者在交易中存在非理性投机倾向,盲目地追涨杀跌不利于股票市场的健康发展。倘若能够利用技术手段对股票价格走势进行预测,同时为投资者提供投资参考建议,那么此举将会促进资本市场的良性发展并提升投资者的收益水平,具有较强的理论和现实意义。本文在股票价格趋势预测中引入深度学习神经网络算法,使用CNN进行股价预测。

从结果来看,使用CNN来处理时间序列数据产生的预测值总体来说还行,但与真实值存在一定出入。对于股票来说,影响股价波动因素繁多,单单从历史股价进行预测未来股价是不足够的,这也符合弱式有效市场假说,即技术分析失败;另一方面,本次实验采用的网络结构较简单,采用更强大的网络进行回归预测任务则会得到更好的效果。

📚2 运行结果

主函数部分代码:

%% 清除工作空间中的变量和图形

clear,clc

close all

%% 1.加载337期上证指数开盘价格

load elm_stock

whos

rng(now)

price=price(:);

train_num=280;

price1=price(1:train_num);  %前280个数据为训练组

price2=price(train_num+1:337);      %后面的数据为测试组

x=price1';

%[x,ps]=mapminmax(x,0,1);   %归一化处理,可自行添加或不加

lag=6;    % 自回归阶数

iinput=x; % x为原始序列(行向量)

n=length(iinput);

%准备输入和输出数据

inputs=zeros(n-lag,lag);

for i=1:n-lag

    inputs(i,:)=iinput(i:i+lag-1)';

end

targets=x(lag+1:end);

%创建网络

P=inputs;

P=P';

T=targets;

net=newff(minmax(P),[10,1],{'logsig','purelin'},'trainlm');

inputWeights=net.IW{1,1} ;

inputbias=net.b{1}; 

layerWeights=net.LW{2,1} ;

layerbias=net.b{2,1} ;

% 避免过拟合,划分训练,测试和验

net.trainParam.show = 50; 

net.trainParam.lr = 0.1; 

net.trainParam.mc = 0.04; 

net.trainParam.epochs = 1000; 

net.trainParam.goal = 1e-5; 

%训练网络

[net,tr] = train(net,P,T);

%% 根据图表判断拟合好坏

yn=net(P);

errors=T-yn;

figure(1)

plot(T,'b-');

hold on

plot(yn,'r--')

legend('股价真实值','BP网络输出值')

title('训练数据的测试结果');

% 显示均方误差

mse1 = mse(errors);

fprintf('    mse = \n     %f\n', mse1)

figure(2)

title('训练数据测试结果的残差')

% 显示相对误差

disp('    相对误差:')

fprintf('%f  ', (T - yn)./T );

fprintf('\n')

%% 预测

% 2.显示测试数据的测试结果

%预测

fn=57;  %预测步数为fn。

f_in=iinput(n-lag+1:end)';

f_out=zeros(1,fn);  %预测输出

% 多步预测时,用下面的循环将网络

for i=1:fn

    f_out(i)=net(f_in);

    f_in=[f_in(2:end);f_out(i)];

end

figure(3)

% 显示真实值

x2=1:length(price2');

plot(price2,'b-');

hold on

% 显示神经网络的输出值

plot(f_out,'r--')

legend('initial data','prediction result');

title('BP prediction');

hold off

grid on

% 显示残差

figure(4)

errors2=price2'-f_out;

mse2=mse(errors2);

plot(mse2)

title('测试数据测试结果的残差')

% 显示均方误差

mse2 = mse(errors2);

fprintf('    mse = \n     %f\n', mse2)

% 显示相对误差

disp('    相对误差:')

fprintf('%f  ', errors2./price2' );

fprintf('\n')

🎉3 参考文献

[1]李晨阳. 基于CNN-LSTM的股票价格预测及量化选股研究[D].西北大学,2021.DOI:10.27405/d.cnki.gxbdu.2021.001928.

👨‍💻4 Matlab代码

相关文章:

时间序列预测--基于CNN的股价预测(Matlab代码实现)

目录 💥1 概述 📚2 运行结果 🎉3 参考文献 👨‍💻4 Matlab代码 💥1 概述 时间序列预测有很多方法,如传统的时序建模方法ARIMA、周期因子法、深度学习网络等,本次实验采用最简单的…...

Dubbo与Spring Cloud优缺点分析(文档学习个人理解)

文章目录核心部件1、总体框架1.1 Dubbo 核心部件如下1.2 Spring Cloud 总体架构2、微服务架构核心要素3、通讯协议3.1 Dubbo3.2 Spring Cloud3.3 性能比较4、服务依赖方式4.1 Dubbo4.2 Spring Cloud5、组件运行流程5.1 Dubbo5.2 Dubbo 运行组件5.3 Spring Cloud5.4 Spring Clou…...

单元测试工具——JUnit的使用

⭐️前言⭐️ 本篇文章主要介绍单元测试工具JUnit的使用。 🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁 🍉博主将持续更新学习记录收获,友友们有任何问题可以在评论区留言 🍉博客中涉及源码…...

Linux_基本权限

Linux入门第二篇已送达! Linux_基本权限shell外壳权限Linux的用户分类角色划分Linux的文件文件类型查看权限目录的权限默认权限粘滞位shell外壳 为了保护操作系统,用户的指令不能由操作系统直接进行执行,需要一个中间者,比如Linu…...

3、JavaScript面试题

1, Js数据类型有哪些?数值、字符串、布尔、undefined、null、数组、对象、函数2, 引用类型和值类型的区别- 值类型存在于栈中, 存取速度快 引用类型存在于堆,存取速度慢- 值类型复制的是值本身 引用类型复制的是指向对象的指针- 值类型结构简单只包含基本数据, 引用…...

YUV图像

YUV的存储方式UV格式有两大类:planar和packed。对于planar的YUV格式,先连续存储所有像素点的Y,紧接着存储所有像素点的U,随后是所有像素点的V。对于packed的YUV格式,每个像素点的Y,U,V是连续交替存储的。YUV的采样主流…...

.net6API使用AutoMapper和DTO

AutoMapper,是一个转换工具,说到AutoMapper时,就不得不先说DTO,它叫做数据传输对象(Data Transfer Object)。 通俗的来说,DTO就是前端界面需要用的数据结构和类型,而我们经常使用的数据实体,是数…...

IO知识整理

IO 面向系统IO page cache 程序虚拟内存到物理内存的转换依靠cpu中的mmu映射 物理内存以page(4k)为单位做分配 多个程序访问磁盘上同一个文件,步骤 kernel将文件内容加载到pagecache多个程序读取同一份文件指向的同一个pagecache多个程…...

【正点原子FPGA连载】第十三章QSPI Flash读写测试实验 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Vitis开发指南

1)实验平台:正点原子MPSoC开发板 2)平台购买地址:https://detail.tmall.com/item.htm?id692450874670 3)全套实验源码手册视频下载地址: http://www.openedv.com/thread-340252-1-1.html 第十三章QSPI Fl…...

深入理解mysql的内核查询成本计算

MySql系列整体栏目 内容链接地址【一】深入理解mysql索引本质https://blog.csdn.net/zhenghuishengq/article/details/121027025【二】深入理解mysql索引优化以及explain关键字https://blog.csdn.net/zhenghuishengq/article/details/124552080【三】深入理解mysql的索引分类&a…...

LeetCode 141. 环形链表

原题链接 难度:easy\color{Green}{easy}easy 题目描述 给你一个链表的头节点 headheadhead ,判断链表中是否有环。 如果链表中有某个节点,可以通过连续跟踪 nextnextnext 指针再次到达,则链表中存在环。 为了表示给定链表中的…...

git提交

文章目录关于数据库:桌面/vue-admin/vue_shop_api 的 git 输入 打开 phpStudy ->mySQL管理器 导入文件同时输入密码,和文件名 node app.js 错误区: $ git branch // git branch 查看分支 只有一个main分支不见master解决: gi…...

Java中常见的编码集问题

收录于热门专栏Java基础教程系列(进阶篇) 一、遇到一个问题 1、读取CSV文件 package com.guor.demo.charset;import java.io.BufferedReader; import java.io.FileReader; import java.util.ArrayList; import java.util.HashMap; import java.util.L…...

数据结构与算法(Java版) | 就让我们来看看几个实际编程中遇到的问题吧!

上一讲,我给大家简单介绍了一下数据结构,以及数据结构与算法之间的关系,照理来说,接下来我就应该要给大家详细介绍线性结构和非线性结构了,但是在此之前,我决定还是先带着大家看几个实际编程中遇到的问题&a…...

【C++算法】dfs深度优先搜索(上) ——【全面深度剖析+经典例题展示】

💃🏼 本人简介:男 👶🏼 年龄:18 📕 ps:七八天没更新了欸,这几天刚搞完元宇宙,上午一直练🚗,下午背四级单词和刷题来着,还在忙一些学弟…...

总结高频率Vue面试题

目录 什么是三次握手? 什么是四次挥手?(close触发) 什么是VUEX? 什么是同源----跨域? 什么是Promise? 什么是fexl布局? 数据类型 什么是深浅拷贝? 什么是懒加载&…...

IP协议详解

目录 前言: IP协议 提出问题 解决方案 地址管理 子网掩码 路由选择 小结: 前言: IP协议作为网络层知名协议。当数据经过传输层使用TCP或者UDP对数据进行封装,然后当数据到达网络层,基于TCP或UDP数据包继续进行…...

webpack5 基础配置

在开发中,我们会使用 vue、react、less、scss等语法进行开发项目,但是浏览器只能识别 js、css,或者说在js中使用了es6中的import 导入 这时候也需要打包工具去转换成浏览器可以识别的语句。 一、使用webpack 1.初始化package.json npm i…...

IDEA入门安装使用教程

一、背景 作为一个Java开发者,有非常多编辑工具供我们选择,比如Eclipse、IntelliJ IDEA、NetBeans、Visual Studio Code、Sublime Text等等,这些有免费也有收费的,但是就目前市场占比来说普遍使用Eclipse和IntelliJ IDEA这两款主…...

Lambda表达式使用及详解

一 Lambda表达式的简介 Lambda表达式(闭包):java8的新特性,lambda运行将函数作为一个方法的参数,也就是函数作为参数传递到方法中。使用lambda表达式可以让代码更加简洁。 Lambda表达式的使用场景:用以简…...

别再死记硬背了!用CAPL脚本在CANoe里实现这5个自动化测试场景,效率翻倍

别再死记硬背了!用CAPL脚本在CANoe里实现这5个自动化测试场景,效率翻倍 刚接触Vector工具链的工程师常陷入一个误区:把大量时间花在记忆CAPL函数语法上,却不知道如何将这些知识转化为实际测试能力。我曾见过团队成员反复查阅手册却…...

Showdown.js 完整指南:轻松实现 Markdown 到 HTML 双向转换

Showdown.js 完整指南:轻松实现 Markdown 到 HTML 双向转换 【免费下载链接】showdown A bidirectional Markdown to HTML to Markdown converter written in Javascript 项目地址: https://gitcode.com/gh_mirrors/sh/showdown 想要在网页中优雅展示 Markdo…...

DeepSeek-V4本地部署全指南:vLLM分布式推理+量化配置

⚙️ 工程深度:L4 生产级 | 📖 预计阅读:30 分钟 为什么写这篇 很多工程师面对 DeepSeek-V4 的部署决策时,第一反应是"自建肯定比 API 贵"。这个直觉并不总是错的,但它忽略了一个基本事实:API 的成本随调用量线性增长,自建的成本是固定的。两条成本曲线必…...

Jetson AGX Xavier刷机救砖全记录:从开机报错‘write error’到联网成功,保姆级避坑指南

Jetson AGX Xavier系统修复与网络配置全流程实战 当你手握一块价值不菲的Jetson AGX Xavier开发板,却遭遇系统崩溃和网络连接双重困境时,那种焦虑感我深有体会。去年在部署边缘计算项目时,我的Xavier突然报出"write error"错误&…...

告别外接显示器亮度调节烦恼:MonitorControl如何让Mac体验更完整?

告别外接显示器亮度调节烦恼:MonitorControl如何让Mac体验更完整? 【免费下载链接】MonitorControl 🖥 Control your displays brightness & volume on your Mac as if it was a native Apple Display. Use Apple Keyboard keys or custo…...

UE5-MCP:重构游戏开发效率的AI驱动解决方案

UE5-MCP:重构游戏开发效率的AI驱动解决方案 【免费下载链接】UE5-MCP MCP for Unreal Engine 5 项目地址: https://gitcode.com/gh_mirrors/ue/UE5-MCP 在当今游戏开发行业,一个残酷的现实是:超过70%的开发时间被消耗在重复性、低价值…...

48个编程挑战带你从入门到精通:2023编程挑战完全指南

48个编程挑战带你从入门到精通:2023编程挑战完全指南 【免费下载链接】retos-programacion-2023 Ejercicios de cdigo semanales en 2023 de la comunidad MoureDev para practicar lgica en cualquier lenguaje de programacin. 项目地址: https://gitcode.com/g…...

从零到一:手把手教你用Docker打包并提交Carla Leaderboard代码(避坑指南)

从零到一:Carla Leaderboard Docker镜像构建与提交全流程实战指南 1. 环境准备与基础配置 在开始构建Carla Leaderboard的Docker镜像前,我们需要确保本地开发环境已经正确配置。不同于普通的Docker应用,自动驾驶评估系统对硬件和软件环境有着…...

如何一次性解决Windows系统VC++运行库缺失难题?VisualCppRedist AIO深度技术解析

如何一次性解决Windows系统VC运行库缺失难题?VisualCppRedist AIO深度技术解析 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 当你在Windows系统上启…...

终极指南:如何用WaveTools快速管理多个鸣潮游戏账号

终极指南:如何用WaveTools快速管理多个鸣潮游戏账号 【免费下载链接】WaveTools 🧰鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 如果你是一位鸣潮玩家,同时拥有多个游戏账号,那么你一定经历过频繁登…...