自建數據分析操盤系統 - 財經

Dinah avatar
By Dinah
at 2018-04-02T16:47

Table of Contents

※ [本文轉錄自 Option 看板 #1QmUqh1N ]

作者: cory8249 (Cory) 看板: Option
標題: [心得] 自建數據分析操盤系統
時間: Mon Apr 2 16:43:21 2018


金融交易變化萬千,到底要怎麼長期穩定賺錢 ?
我想是每個操盤投資人都想解的問題

但真的有規律可尋嗎 ?
某某書寫說看 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 形式回傳註冊的商品即時成交明細

那如何蒐集 有系統化的保存這些資料 供接下來分析使用 ?
這時候勢必就把資料庫系統派上用場了

我是用 PostgrSQL 而不是 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

William avatar
By William
at 2018-04-02T18:01
先推不然別人會發現我看不懂
Tom avatar
By Tom
at 2018-04-02T19:15
還好我看的懂, 技術上是還好 不過全部做完是個大坑
Olive avatar
By Olive
at 2018-04-02T20:30
我韌體的我看不懂
Kelly avatar
By Kelly
at 2018-04-02T21:44
原po太強大了,做成這樣真的很猛,我用R做,可是沒那麼
多功能
Regina avatar
By Regina
at 2018-04-02T22:59
做這很累,加油
Victoria avatar
By Victoria
at 2018-04-03T00:13
先給Cory大推一個
Charlie avatar
By Charlie
at 2018-04-03T01:28
弄這些東西出來能賺錢嗎???我覺得是重點耶…(非吐潮)
Odelette avatar
By Odelette
at 2018-04-03T02:42
所以你打造了一個看盤+下單+歷史數據系統,令人佩服
Tristan Cohan avatar
By Tristan Cohan
at 2018-04-03T03:57
感覺有點深奧
Erin avatar
By Erin
at 2018-04-03T05:11
如果可以開發成類似像Quantopia的環境給大家開發台股
Suhail Hany avatar
By Suhail Hany
at 2018-04-03T06:26
程式交易就好了.國內的MC又差又貴,與其浪費時間在台股
Erin avatar
By Erin
at 2018-04-03T07:40
不如去國外一堆免費平台開發(基本上免費,進階要收費)
Iris avatar
By Iris
at 2018-04-03T08:55
這些分析TS或MC都做得到,專心開發Algo Trade找到自己的ed
ge才是重中之重,除非你只是要賣股市分析軟體。寫algo時會
反過來思考要用那種分析才有edge?適合自己的risk管理?何
處加碼或停利停損?等這些都找到後你會發現這時的分析跟當
初想的已經很不一樣。
Thomas avatar
By Thomas
at 2018-04-03T10:09
如果您的初衷是數據分析,旁觀來看似乎有些本末倒置了。
不管是要朝視覺化還是深度學習,花一個晚上把 raw data
準備好其實就可以開始了
Rebecca avatar
By Rebecca
at 2018-04-03T11:24
寫這個真的很累...推一個,感覺真的可以賣給券商了...
Wallis avatar
By Wallis
at 2018-04-03T12:38
現在看盤軟體真的很爛,跟過去比完全沒進步...
Callum avatar
By Callum
at 2018-04-03T13:53
我也做了一套 結果…還是沒賺錢
Noah avatar
By Noah
at 2018-04-03T15:07
為了要喝自己想喝的牛奶 養了一頭牛 辛苦你了
David avatar
By David
at 2018-04-03T16:22
要不要順便開間公司 賣你的服務或軟體? XD
Kama avatar
By Kama
at 2018-04-03T17:36
現成軟體限制很多,自己做系統有其價值,大大有考慮賣?
Odelette avatar
By Odelette
at 2018-04-03T18:51
小弟也自己想寫演算法,但是進階一點的似乎都非得自己做
Agnes avatar
By Agnes
at 2018-04-03T20:05
一套framework,現成的限制一大堆,要做複雜東西很有難度
Megan avatar
By Megan
at 2018-04-03T21:20
卷商有提供 api 可以收 raw data 可以下 order 就夠了,
限制在哪裡?有心踏入演算法,用一些 data science 的 li
brary 從 raw data 去發展,何必用別人的框架?捨簡取繁
作繭自縛,不懂
Joseph avatar
By Joseph
at 2018-04-03T22:34
這太強了,要推!
Candice avatar
By Candice
at 2018-04-03T23:49
認真給推,我們交易室老大也是自己弄了一套
Caitlin avatar
By Caitlin
at 2018-04-04T01:03
光看就覺得好厲害
Hazel avatar
By Hazel
at 2018-04-04T02:18
太強
Linda avatar
By Linda
at 2018-04-04T03:32
太強大了
Eden avatar
By Eden
at 2018-04-04T04:47
我覺得你可以賣軟體了 板上應該很多人會買
Christine avatar
By Christine
at 2018-04-04T06:01
問一下 不玩比特幣了嗎
Doris avatar
By Doris
at 2018-04-04T07:16
你可以認真考慮找創業夥伴再拉金主 做成服務型產品
Linda avatar
By Linda
at 2018-04-04T08:30

4月愚人節閒聊

Jacob avatar
By Jacob
at 2018-04-02T12:53
4月愚人節 很多聰明人都說and#34;我很笨and#34;,所以其實這是聰明人的節日 - ...

期貨交易人才訓練班-(政府補助)

Kama avatar
By Kama
at 2018-03-30T13:26
※ [本文轉錄自 unemployed 看板 #1QlScH68 ] 作者: ASL88 (阿池) 看板: unemployed 標題: [情報] 期貨交易人才訓練班-(政府補助) 時間: Fri Mar 30 13:22:21 2018 課程名稱:期貨交易人才訓練班-(政府補助) 課程代碼:111795 ...

徵二手MC

Kyle avatar
By Kyle
at 2018-03-24T19:27
欲徵二手MC中文版,請報價,謝謝! ----- Sent from JPTT on my Asus ASUS_Z00AD. - ...

TOZZI 權證投資實戰賽 第二季 開放報名

Oliver avatar
By Oliver
at 2018-03-23T10:41
投資權證以小博大再賺獎金!「TOZZI 第2季權證投資實戰賽」敢來挑戰,再說你厲害! 最真實、最具挑戰性的投資競賽 ──「TOZZI 權證投資實戰賽」最新第2季賽事即將開賽 !新的一季,我們賽制、網站全新改版!力邀以往參賽的選手及更多挑戰者一起再創佳績! 賽事:TOZZI 第2季權證投資實戰賽 報名時間 ...

Algorithm/Quant Trading Developer

Cara avatar
By Cara
at 2018-03-16T21:09
As a Venture Studio, we develop multiple ventures simultaneously- focusing on building innovative technology solutions and turning them into sustainable bu ...