摘要 | 第5-6页 |
ABSTRACT | 第6-7页 |
第一章 绪论 | 第11-16页 |
1.1 远程调用框架的概念 | 第11页 |
1.2 量化投资的概念与意义 | 第11-12页 |
1.3 量化投资测试系统的作用与目地 | 第12页 |
1.4 量化回测系统的现状 | 第12-13页 |
1.4.1 交易策略与回测系统之间耦合过紧 | 第12-13页 |
1.4.2 扩展性能差 | 第13页 |
1.4.3 最大行情容量有限 | 第13页 |
1.4.4 测试框架与交易框架差异大 | 第13页 |
1.5 基于C++远程调用框架与回测系统的关系 | 第13页 |
1.6 测试系统的特点 | 第13-14页 |
1.7 论文的章节安排 | 第14-16页 |
第二章 项目使用的相关技术的介绍 | 第16-21页 |
2.1 远程调用RPC的相关概念 | 第16-17页 |
2.1.1 RPC的概念 | 第16页 |
2.1.2 Java远程方法调用 | 第16页 |
2.1.3 CORBA概念 | 第16-17页 |
2.2 数据库技术 | 第17-18页 |
2.2.1 Microsoft Software SQL Server | 第17-18页 |
2.3 序列化与反序列化库Protobuf | 第18页 |
2.3.1 Protobuf的优点 | 第18页 |
2.3.2 Protobuf的不足 | 第18页 |
2.4 编译环境开发环境与编译器 | 第18-20页 |
2.4.1 GNU GCC | 第19页 |
2.4.2 Cygwin | 第19页 |
2.4.3 Boost程序库 | 第19-20页 |
2.4.4 WAF编译系统 | 第20页 |
2.5 动态加载技术 | 第20页 |
2.6 本章小结 | 第20-21页 |
第三章 量化回测系统的需求分析 | 第21-30页 |
3.1 现有系统的分析 | 第21-22页 |
3.2 现有回测系统执行流程 | 第22-24页 |
3.2.1 创建参数空间 | 第22-23页 |
3.2.2 创建策略实例集合 | 第23页 |
3.2.3 加载行情 | 第23页 |
3.2.4 播放行情并取得结果 | 第23-24页 |
3.2.5 收集测试结果并结束 | 第24页 |
3.3 新回测交易系统需求分析 | 第24-26页 |
3.3.1 完整的抽象接口 | 第24页 |
3.3.2 策略与框架的相互隔离 | 第24页 |
3.3.3 计算能力的可扩展性 | 第24-25页 |
3.3.4 提高行情缓存的高命中率 | 第25页 |
3.3.5 解除行情运算容量限制 | 第25-26页 |
3.4 新系统的流程分析 | 第26-29页 |
3.4.1 新系统总体业务流程 | 第26-27页 |
3.4.2 前端节点的流程设计 | 第27-28页 |
3.4.3 后端节点的流程设计 | 第28-29页 |
3.5 本章小结 | 第29-30页 |
第四章 新回测系统的设计 | 第30-50页 |
4.1 系统设计的目标 | 第30页 |
4.2 系统体系结构设计 | 第30-32页 |
4.3 功能模块设计 | 第32-34页 |
4.4 测试容器模块详细设计 | 第34-47页 |
4.4.1 数据结构定义 | 第34-39页 |
4.4.2 测试/交易框架与策略的交互接口 | 第39-47页 |
4.5 数据库相关设计 | 第47-49页 |
4.6 本章小结 | 第49-50页 |
第五章 新回测系统的实现 | 第50-72页 |
5.1 ILogger接口的实现NullLogger | 第50页 |
5.2 IConfigureManager接口的实现TestConfigureManager | 第50页 |
5.3 最小缓存单元在内存中的实现MarketDataStore | 第50-51页 |
5.4 DataCache的实现 | 第51-52页 |
5.5 IMarketDataProvider接口MarketDataReplayerMultiThread | 第52-53页 |
5.6 前端对节点的选择 | 第53-55页 |
5.7 回测框架的容器类TestFixture | 第55-61页 |
5.7.1 启动远程IO线程 | 第55-56页 |
5.7.2 创建策略实例组 | 第56页 |
5.7.3 对每一个策略运行一天的测试runDataOnDay | 第56-57页 |
5.7.4 创建本地IO线程 启动测试运行 | 第57-59页 |
5.7.5 创建运行测试的线程组 | 第59-60页 |
5.7.6 等待测试运行结束 | 第60页 |
5.7.7 运行结束搜集测试结果 | 第60-61页 |
5.8 IOrderManager接口的实现FakeOrderManger | 第61-62页 |
5.9 ITimerProvider接口的实现FakeTimerProvider | 第62-64页 |
5.10 新回测系统的外围模块设计 | 第64-70页 |
5.10.1 外围模块通信消息定义 | 第64-67页 |
5.10.2 外围模块设计 | 第67-70页 |
5.11 本章小结 | 第70-72页 |
第六章 系统的部署编译运行与测试 | 第72-76页 |
6.1 章节概述 | 第72页 |
6.2 系统的部署与编译 | 第72-73页 |
6.2.1 系统需求 | 第72页 |
6.2.2 系统部署与编译 | 第72-73页 |
6.3 运行与测试 | 第73-74页 |
6.4 并行化运行的性能测试 | 第74-75页 |
6.5 本章小结 | 第75-76页 |
第七章 论文结论与展望 | 第76-77页 |
7.1 本课题的主要研究成果 | 第76页 |
7.2 本课题下一步发展的方向与展望 | 第76-77页 |
致谢 | 第77-78页 |
参考文献 | 第78-80页 |