自建數據分析操盤系統 - 期貨

By Xanthe
at 2018-04-02T16:43
at 2018-04-02T16:43
Table of Contents
金融交易變化萬千,到底要怎麼長期穩定賺錢 ?
我想是每個操盤投資人都想解的問題
但真的有規律可尋嗎 ?
某某書寫說看 OOXX 指標金叉做多 勝率 80% 真的嗎 ?
某某老師說 他的程式回測績效超猛 去年賺五倍 現在我租了 也要發了嗎 ?
還是跟著鄉民反著做 聽說勝率很高 ?
以上都是我剛入場時,心裡的疑惑。充滿茫然,不知所措。
既然這樣,身為一個資工系宅宅,乾脆自己用擅長的程式,實做數據分析吧!
那要怎麼做? 要寫 MultiCharts 嗎? 還是自己寫 Excel DDE? C# API?
--
經過了一些嘗試與挫折後
我發現市面上沒有任何一套工具可以滿足我做程式化數據分析的追求
( 可能我的追求比較奇怪 )
所以決定走上一條困難的路
就是從頭到尾 打造一套分析操盤系統
從底層原始資料收集、資訊庫系統、演算法設計、圖表視覺化、網站前端即時呈現
全部動手 DIY 自己做!
https://i.imgur.com/QGlS3WZ.png
https://i.imgur.com/398CbpW.png
https://i.imgur.com/ZRMY8Bp.png
--
以下分享這一年來做的工程細節
沒有任何聖杯程式指標 也沒有交易策略
僅為數據分析系統實做經驗談
沒興趣請趕快左轉 XDD
--
首先 交易的 Raw Data 到底是什麼呢 ? K棒嗎 ? 均線 ?
就我目前來看,盤中主要有兩個:成交明細、五檔掛單
https://i.imgur.com/GOYB90D.png
K棒、線、技術指標,都是衍生來的,並非真正原始資料
所以做數據工程,勢必要收集最原始的 data
以台指期來看 每天成交約 6-7萬筆 10-15萬口
如何收集這 幾萬筆 Data 來分析 勢必要透過行情報價API來達成
國內免費的 Tick 報價 我是用群益 C# API
它會以 Callback 形式回傳註冊的商品即時成交明細
那如何蒐集 有系統化的保存這些資料 供接下來分析使用 ?
這時候勢必就把資料庫系統派上用場了
我是用 PostgreSQL 而不是 txt csv 文字檔格式
資料正規化 永續性儲存 對後續分析跟維護 有非常大益處
https://i.imgur.com/zcHVA5J.png
目前抓的商品包含: 大台 小台 周選 月選 指標性權值股 (不知不覺也累積3000萬筆了)
涵蓋大部分人會看 有意義的標的商品
之後要做各種不同的分析 都會有幫助
有報價即時存到資料庫之後 接下來要開始認真要做分析
這邊我選擇我擅長的 Python 來做 而不是直接寫在 C#
畢竟在資料分析的領域 毋庸置疑 Python 是目前最強大的
也為之後要導入 AI / Deep Learning Model 做準備
分析程式部份 目前實做幾個我覺得很有意思的
1. 大戶/散戶 成交累積變化
2. 選擇權均價 / 累積金額
3. 權值股開盤後當天強弱走勢
4. 權值股大單走向
5. 期貨買賣掛單變化
細節就不講了 反正有資料想算什麼都可以 大家有興趣可以自己做
畢竟每個人想看的的分析、操作方式都不一樣
這邊可以看出 如果不自己做系統 現成軟體是很難辦到這些事情的
不論 MC 還是 Excel 都幾乎得不到我要的分析
再者 我真正想做的分析 才剛開始 XD
--
分析演算法寫完之後 就要考慮怎麼呈現 讓K棒會跳 圖表數值會更新
直接 Python Matplotlib 絕對是不行的
寫 Qt/wx GUI 我覺得也不是一個好方法
好在現在網頁 js 前端 有一套很棒的 Lib 就是 TradingView
之前玩比特幣 發現很多交易所都用那套 可以接自己的 API 即時畫圖表
所以大部分指標線圖性質的分析 我都把它寫成 Web REST API
串接 TradingView 可以很縮放流暢的觀看
( 哀 看看現在的券商軟體 跟我小時候看我爸在玩的時候 根本沒什麼改變 ...
非線圖類的分析 就要用 React / Chart.js 來寫了
可以畫圓餅圖、長條圖、泡泡圖等等
一樣先想好要做什麼 怎麼開 Data API 怎麼呈現
像是我覺得把選擇權 Call / Put 對稱上下擺 用長條圖就很棒
--
架構大概是這樣 中間還蠻多坑的 每個環節就是熬夜無數天才搞出來的
也陸續找了一些人 組發開團隊 越弄越大
( 不然後端、DB、前端、演算法、交易操盤、策略分析 一個人吃不下啊 XD
POST INSERT
C# Quote API ------> Python Django --------> PostgreSQL
SELECT GET
PostgreSQL --------> Numpy / Pandas ---> Django REST API -----> TradingView
-----> React/Chart.js
^
DLL |
MC 策略 ------> Firebase DB ----------------------------------*
然後 ... 最近又開始大改版了 因為這樣無法達到 Realtime 的速度
所以開始接 Redis / RabbitMQ 同時雙 DB 雙報價源備援 避免群益 API 會斷線/漏資料
之後導入 WebSocket 推播 也會比 Polling 更有效率
同時也開始弄下單機 取代 MC 這個讓我很不爽的東西 ...
搭配 LINE Bot 監控觸發推播 部位風險計算警示等等
終極目標: 全功能網頁版分析操盤系統 + 進階演算法自動下單 + 風控系統
大概是這樣 一點心得 供大家參考
只能說 做這個真的很累 非誠勿試
光是搞 Infrastructure 就弄半天
到底什麼時候可以重新回歸 專心開發 Algo Trade 呢
還有更深奧的 AI / Deep Learning Model
找了幾篇 paper 一直沒時間去實做 都快要忘記 TensorFlow 怎麼寫了 XD
--
Tags:
期貨
All Comments

By Lauren
at 2018-04-07T06:59
at 2018-04-07T06:59

By Erin
at 2018-04-09T07:55
at 2018-04-09T07:55

By Audriana
at 2018-04-12T21:52
at 2018-04-12T21:52

By Thomas
at 2018-04-14T20:34
at 2018-04-14T20:34

By Heather
at 2018-04-17T09:33
at 2018-04-17T09:33

By Isabella
at 2018-04-19T18:32
at 2018-04-19T18:32

By Tom
at 2018-04-20T02:43
at 2018-04-20T02:43

By Erin
at 2018-04-20T16:26
at 2018-04-20T16:26

By Lauren
at 2018-04-22T22:34
at 2018-04-22T22:34

By Blanche
at 2018-04-23T06:32
at 2018-04-23T06:32

By Ethan
at 2018-04-28T04:31
at 2018-04-28T04:31

By Susan
at 2018-05-02T21:43
at 2018-05-02T21:43

By Franklin
at 2018-05-04T09:27
at 2018-05-04T09:27

By Susan
at 2018-05-06T09:14
at 2018-05-06T09:14

By Hedy
at 2018-05-07T23:44
at 2018-05-07T23:44

By Jacky
at 2018-05-08T08:38
at 2018-05-08T08:38

By Hedy
at 2018-05-08T19:16
at 2018-05-08T19:16

By Lucy
at 2018-05-11T05:33
at 2018-05-11T05:33

By Puput
at 2018-05-14T06:00
at 2018-05-14T06:00

By Wallis
at 2018-05-19T04:45
at 2018-05-19T04:45

By Emma
at 2018-05-23T12:40
at 2018-05-23T12:40

By Elvira
at 2018-05-26T18:32
at 2018-05-26T18:32

By Ingrid
at 2018-05-29T14:16
at 2018-05-29T14:16

By Poppy
at 2018-06-03T08:10
at 2018-06-03T08:10

By Poppy
at 2018-06-06T22:14
at 2018-06-06T22:14

By Connor
at 2018-06-10T03:26
at 2018-06-10T03:26

By Hedwig
at 2018-06-11T07:09
at 2018-06-11T07:09

By Liam
at 2018-06-13T23:55
at 2018-06-13T23:55

By Jack
at 2018-06-17T20:48
at 2018-06-17T20:48

By Faithe
at 2018-06-18T22:43
at 2018-06-18T22:43

By Hedda
at 2018-06-22T08:04
at 2018-06-22T08:04

By Agatha
at 2018-06-24T06:00
at 2018-06-24T06:00

By Leila
at 2018-06-28T10:01
at 2018-06-28T10:01

By Robert
at 2018-06-28T20:00
at 2018-06-28T20:00

By Erin
at 2018-07-01T17:10
at 2018-07-01T17:10

By Frederica
at 2018-07-02T02:33
at 2018-07-02T02:33

By Jack
at 2018-07-03T04:05
at 2018-07-03T04:05

By Megan
at 2018-07-04T08:40
at 2018-07-04T08:40

By Damian
at 2018-07-04T11:15
at 2018-07-04T11:15

By Lydia
at 2018-07-08T03:20
at 2018-07-08T03:20

By Heather
at 2018-07-09T19:07
at 2018-07-09T19:07

By Barb Cronin
at 2018-07-14T01:43
at 2018-07-14T01:43

By Franklin
at 2018-07-18T16:11
at 2018-07-18T16:11

By Mason
at 2018-07-22T04:29
at 2018-07-22T04:29

By Dinah
at 2018-07-23T23:20
at 2018-07-23T23:20

By Candice
at 2018-07-27T03:58
at 2018-07-27T03:58

By Lily
at 2018-07-28T04:01
at 2018-07-28T04:01

By Sarah
at 2018-07-29T08:11
at 2018-07-29T08:11

By Hazel
at 2018-08-02T10:24
at 2018-08-02T10:24

By Freda
at 2018-08-07T09:43
at 2018-08-07T09:43

By Mason
at 2018-08-08T19:07
at 2018-08-08T19:07

By Zora
at 2018-08-13T00:54
at 2018-08-13T00:54

By Mary
at 2018-08-15T20:38
at 2018-08-15T20:38

By Eden
at 2018-08-19T21:48
at 2018-08-19T21:48

By Andy
at 2018-08-22T09:35
at 2018-08-22T09:35

By Irma
at 2018-08-25T16:37
at 2018-08-25T16:37

By Mason
at 2018-08-30T10:12
at 2018-08-30T10:12

By Tom
at 2018-09-03T13:05
at 2018-09-03T13:05

By Edwina
at 2018-09-06T05:05
at 2018-09-06T05:05

By Una
at 2018-09-07T13:16
at 2018-09-07T13:16

By Rachel
at 2018-09-09T04:05
at 2018-09-09T04:05

By John
at 2018-09-11T03:22
at 2018-09-11T03:22

By Elma
at 2018-09-15T14:24
at 2018-09-15T14:24

By Selena
at 2018-09-17T22:16
at 2018-09-17T22:16

By Kama
at 2018-09-19T01:32
at 2018-09-19T01:32

By Jacky
at 2018-09-22T02:56
at 2018-09-22T02:56

By Caroline
at 2018-09-22T15:27
at 2018-09-22T15:27

By Catherine
at 2018-09-26T19:22
at 2018-09-26T19:22

By Ula
at 2018-09-27T01:33
at 2018-09-27T01:33

By John
at 2018-09-30T17:21
at 2018-09-30T17:21

By Poppy
at 2018-09-30T23:08
at 2018-09-30T23:08

By Megan
at 2018-10-02T18:22
at 2018-10-02T18:22

By Adele
at 2018-10-06T22:02
at 2018-10-06T22:02

By Queena
at 2018-10-10T14:14
at 2018-10-10T14:14

By Ivy
at 2018-10-15T02:40
at 2018-10-15T02:40

By Brianna
at 2018-10-17T21:58
at 2018-10-17T21:58

By Kyle
at 2018-10-21T09:38
at 2018-10-21T09:38

By Gilbert
at 2018-10-26T09:18
at 2018-10-26T09:18

By Caitlin
at 2018-10-27T11:52
at 2018-10-27T11:52

By Ursula
at 2018-11-01T06:14
at 2018-11-01T06:14
Related Posts
幫散戶統計每日輸贏

By Steve
at 2018-04-02T15:10
at 2018-04-02T15:10
107年04月02日 三大法人買賣金額統計表

By Frederica
at 2018-04-02T15:00
at 2018-04-02T15:00
107年04月02日 期貨收盤價&結算價一覽表

By Faithe
at 2018-04-02T14:54
at 2018-04-02T14:54
2018/04/02 盤後閒聊

By Rosalind
at 2018-04-02T14:05
at 2018-04-02T14:05
輕鬆獲利1萬元(4日交易日)

By Hedy
at 2018-04-02T11:43
at 2018-04-02T11:43