Giter VIP home page Giter VIP logo

quantfabric's Introduction

QuantFabric开发学习参考资料

QuantFabric量化交易系统

QuantFabric简介

  • QuantFabric是基于Linux/C++开发的中高频量化交易系统,支持中金所、郑商所、大商所、上期所、上海国际能源中心的期货业务品种交易,支持上交所、深交所的股票、债券品种交易。

  • QuantFabric目前支持期货交易柜台如下:

    • CTP
    • 盛立REM
    • 易达YD
  • QuantFabric目前支持股票交易柜台如下:

    • 宽睿OES
  • QuantFabric计划支持股票交易柜台如下:

    • 中泰XTP
    • 华鑫奇点
    • 华锐ATP
  • QuantFabric量化交易系统架构如下:

编译构建

QuantFabric

  • 登录GitCode或GitHub,增加SSH Key认证方式
  • QuantFabric量化交易系统下载:
git clone --recursive [email protected]:QuantFabric/QuantFabric.git
  • QuantFabric编译构建:
cd QuantFabric			# 进入QuantFabric目录
git submodule init		# 初始化子模块
git submodule update --remote	# 更新子模块
sh build_release.sh		# 编译构建
  • 编译构建完成时,可执行文件和so文件位于build目录下。

  • 单个子模块更新代码:

cd XMonitor
git pull origin master
  • 多个子模块遍历更新代码:
git submodule update --remote
git submodule foreach 'git pull origin master'

XMonitor

  • GUI客户端XMonitor编译构建流程如下:
  cd XMonitor				# 进入XMonitor目录
  git pull
  git submodule init		# 初始化子模块
  git submodule update --remote	# 更新子模块
  mkdir build
  cd build
  qmake ..
  make
  • 编译完成时,可执行文件位于build目录下。
  • 由于CMake对于Qt工程构建不完美,本人仍然使用qmake对XMonitor进行单独编译构建。如果需要使用CMake构建XMonitor,请参看CMake构建Qt工程实践

QuantFabric模块

Utils

  • 基础工具模块,提供交易系统不同组件共用的工具模块,如配置加载模块、HPPackClient客户端、HPPackServer服务端、SQLiteManager数据库操作、Singleton单例、Logger日志、RingBuffer、LockFreeQueue无锁队列、IPCMarketQueue行情消息队列、IPCLockFreeQueue内存队列、SnapShotHelper快照工具、时间戳函数、字符串工具函数、不同组件消息通信协议。
  • 项目地址:Utils

XAPI

  • 第三方库,包括SPDLog日志库、HPSocket通信框架、YAML-CPP解析库、CTP柜台API、REM柜台API、YD柜台API、ConcurrentQueue并发队列、OES柜台API。
  • 项目地址:XAPI

XServer

  • 中间件,主要功能如下:
    • 转发GUI客户端上行控制命令到不同Colo交易服务器,如转发XMonitor的报单撤单请求消息到XTrader、风控控制命令消息至XRiskJudge;
    • 转发交易相关数据到GUI客户端,如转发XMarketCenter行情数据、XTrader订单回报至XMonitor。
    • 管理XMonitor客户端登录用户的权限校验。
    • 盘后提供历史数据回放。
  • 项目地址:XServer

XWatcher

  • 监控组件,提供Colo交易服务器上部署的交易组件的监控,并负责转发数据。主要功能如下:
    • 转发XServer转发的控制命令,如报单、撤单、风控参数修改等。
    • 转发Colo交易进程如XMarketCenter、XTrader、XRiskJuage等交易、监控数据至XServer。
    • 监控Colo交易服务器实时性能指标、App交易进程状态,并将相应状态转发至XServer。
  • 项目地址:XWatcher

XMarketCenter

  • 行情网关,采用插件架构,适配不同Broker柜台行情API,主要功能如下:
    • 收取行情数据;
    • 打包行情切片数据写入共享内存队列;
    • 行情数据落地;
    • 行情数据转发至XWatcher监控组件。
  • 项目地址:XMarketCenter

XRiskJudge

  • 风控系统,主要功能如下:
    • 提供账户间风控,如流速控制、账户锁定、自成交、撤单限制检查等风控功能;
    • 加载风控参数,解析XServer转发的风控控制命令,更新风控参数,发送风控参数至XWatcher;
    • 接收XTrader报单、撤单请求,进行风控检查,发送风控检查结果至XTrader;
    • 接收XTrader报单回报、撤单回报,管理订单状态,Ticker交易日内累计撤单计数。
  • 项目地址:XRiskJudge

XTrader

  • 交易网关,采用插件架构适配不同Broker柜台交易API,主要功能如下:
    • 从网络客户端收取手动报单、撤单请求。
    • 从Order内存队列读取报单、撤单请求。
    • 执行报单、撤单指令,管理订单回报。
    • 将仓位、资金、订单回报写入Report内存队列。
    • 将仓位、资金、订单回报发送至XWatcher。
  • 项目地址:XTrader

HFTrader高频交易组件

  • 商业版,不开源。
  • HFTrader性能指标如下:
Perf Indicator:Tick2Order (ns)
count: 405
min: 785
max: 3237
first: 785
mean: 1275.87
median: 1147
std: 449.36
10%: 916
20%: 951
30%: 1002
40%: 1076
50%: 1147
60%: 1249
70%: 1335
75%: 1395
80%: 1460
85%: 1525
90%: 1673
95%: 2390
99%: 3012

Tools

  • 工具箱,提供工具如下:
    • OrderSend:提供批量报单功能,订单写入内存队列。
    • MarketReader:提供行情数据导出功能,从内存行情队列导出行情数据。
  • 项目地址:Tools

FinTechUI

  • 基于Qt封装的金融科技UI组件,支持冻结列TableView、多层次表头HeaderView、自定义排序过滤模型、自定义Button代理、自定义Progress代理、自定义ComboBox代理、自定义表格模型XTableModel、可拖拽式UI插件框架。
  • 项目地址:FinTechUI

XMonitor

  • GUI监控客户端,功能特性如下:
    • 通过拖拽式插件架构实现不同插件页的分屏幕显示,为交易、策略、IT生产运维等人员提供良好GUI体验;
    • 提供Colo交易服务器实时性能指标和交易组件进程状态有效监控;
    • 提供交易组件的进程级管理,实现GUI客户端启动、停止交易组件;
    • 提供行情数据展示、订单回报管理、报单、撤单、风控管理、用户权限管理、交易进程管理等功能。
  • XMonitor客户端提供Permission、Market、EventLog、Monitor、RiskJudge、OrderManager等插件,用于展示不同监控信息。
  • 项目地址:XMonitor
  • Permission插件:提供用户插件权限管理,消息数据订阅。如下:

  • Market插件:展示所有接收Ticker的行情数据。如下:

  • EventLog插件:展示交易系统所有组件的事件日志。如下:

  • Monitor插件:展示Colo交易服务器实时性能指标,交易进程实时状态,提供交易进程管理功能。如下:

  • RiskJudge插件:提供风控系统流速限制、Ticker撤单限制、订单撤单限制相关参数设置;提供账户锁定功能;展示不同账户不同Ticker的累计撤单次数;展示风控系统事件日志。如下:

  • OrderManager插件:提供报单、撤单功能;展示账户仓位信息;展示账户挂单信息;展示账户历史订单记录;展示账户资金信息。如下:

参考资料

quantfabric's People

Contributors

scorpiostudio avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar

quantfabric's Issues

Compile Error in building

when I sh build_release.sh, and compile the XWatcher_0.5.1 failed, the result is below:

[ 16%] Linking CXX executable ../XWatcher_0.5.1
/usr/bin/ld: CMakeFiles/XWatcher_0.5.1.dir/WatcherEngine.cpp.o: in function `Utils::LoadXWatcherConfig(char const*, Utils::XWatcherConfig&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >&) [clone .constprop.0]':
/root/QuantFabric/XWatcher/../Utils/YMLConfig.hpp:578: undefined reference to `YAML::LoadFile(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)'
/usr/bin/ld: CMakeFiles/XWatcher_0.5.1.dir/WatcherEngine.cpp.o: in function `YAML::detail::node_ref::set_scalar(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&)':

What's more, I write #include "yaml-cpp/node/parse.h" on the above of YMLConfig.hpp, however it failed both.

GCC: gcc (Ubuntu 9.3.0-10ubuntu2) 9.3.0
Environment: Ubuntu20.04 in WSL;
git submodule info:
73e4c4ca771686308be4a7576226923651a0690b Tools (heads/master)
a04c8b6c9a7f389ae7d8ad9b62a2af02d4959c0a Utils (heads/master)
b70fcbe4afffebd347ca1e539890917a81f6aa71 XAPI (heads/master)
43f46333a27c00b60c06b0174ad9412aceed6ff1 XDataPlayer (0.2.0-3-g43f4633)
f77bf74647bca50c8c8776444a19a5dd0c27ca78 XMarketCenter (0.8.0-4-gf77bf74)
0c153ea1a99571a5e5a29aa2bc338e4604d10ebf XMonitor (0.9.0-5-g0c153ea)
0ad397a037e35f999c5f33f13784175945fcdbcb XRiskJudge (0.8.0-4-g0ad397a)
89d9aeeae468ad6bc12e64fea166f420df534572 XServer (0.8.0-4-g89d9aee)
8f8118fe93a93c7f0ed2323f66b70fb505278435 XTrader (0.8.0-2-g8f8118f)
54415c5ef16603bb4355043bcdd316210f6a6992 XWatcher (0.5.0-6-g54415c5)

what can I do to solve the problem?

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.